@prisma/client 7.4.0-integration-parameterization.19 → 7.4.0-integration-parameterization.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/generator-build/index.js +40 -5
- package/package.json +34 -34
- package/runtime/client.js +2 -2
- package/runtime/client.js.map +1 -1
- package/runtime/client.mjs +2 -2
- package/runtime/client.mjs.map +1 -1
- package/runtime/wasm-compiler-edge.js +2 -2
- package/runtime/wasm-compiler-edge.js.map +2 -2
- package/runtime/wasm-compiler-edge.mjs +2 -2
- package/runtime/wasm-compiler-edge.mjs.map +2 -2
- package/scripts/default-index.js +1 -1
package/runtime/client.mjs.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../node_modules/.pnpm/@prisma+engines-version@7.4.0-8.534ac5c12b9088d160899554cc8c11039ffb9738/node_modules/@prisma/engines-version/package.json", "../../../node_modules/.pnpm/@prisma+engines-version@7.4.0-8.534ac5c12b9088d160899554cc8c11039ffb9738/node_modules/@prisma/engines-version/index.js", "../../../node_modules/.pnpm/min-indent@1.0.1/node_modules/min-indent/index.js", "../../../node_modules/.pnpm/indent-string@4.0.0/node_modules/indent-string/index.js", "../../../node_modules/.pnpm/new-github-issue-url@0.2.1/node_modules/new-github-issue-url/index.js", "../../../node_modules/.pnpm/js-levenshtein@1.1.6/node_modules/js-levenshtein/index.js", "../../ts-builders/src/TypeBuilder.ts", "../../ts-builders/src/KeyType.ts", "../../../node_modules/.pnpm/@noble+hashes@1.7.1/node_modules/@noble/hashes/src/_assert.ts", "../../../node_modules/.pnpm/@noble+hashes@1.7.1/node_modules/@noble/hashes/src/_u64.ts", "../../../node_modules/.pnpm/@noble+hashes@1.7.1/node_modules/@noble/hashes/src/cryptoNode.ts", "../../../node_modules/.pnpm/@noble+hashes@1.7.1/node_modules/@noble/hashes/src/utils.ts", "../../../node_modules/.pnpm/@noble+hashes@1.7.1/node_modules/@noble/hashes/src/sha3.ts", "../../../node_modules/.pnpm/@paralleldrive+cuid2@2.2.2/node_modules/@paralleldrive/cuid2/src/index.js", "../../../node_modules/.pnpm/@paralleldrive+cuid2@2.2.2/node_modules/@paralleldrive/cuid2/index.js", "../src/runtime/core/extensions/index.ts", "../src/runtime/core/extensions/defineExtension.ts", "../src/runtime/core/extensions/getExtensionContext.ts", "../src/runtime/core/public/index.ts", "../src/runtime/core/public/validator.ts", "../../client-common/src/Cache.ts", "../../client-common/src/casing.ts", "../../client-common/src/Dictionary.ts", "../../client-common/src/lazyProperty.ts", "../../client-common/src/runtimeDataModel.ts", "../src/runtime/core/jsonProtocol/serializeJsonQuery.ts", "../../../node_modules/.pnpm/kleur@4.1.5/node_modules/kleur/colors.mjs", "../../debug/src/index.ts", "../../../node_modules/.pnpm/strip-indent@4.0.0/node_modules/strip-indent/index.js", "../../internals/src/utils/prismaPostgres.ts", "../../internals/src/logger.ts", "../../internals/src/utils/assertNever.ts", "../../../node_modules/.pnpm/ansi-regex@6.1.0/node_modules/ansi-regex/index.js", "../../../node_modules/.pnpm/strip-ansi@7.1.0/node_modules/strip-ansi/index.js", "../../internals/src/utils/path.ts", "../../internals/src/utils/hasOwnProperty.ts", "../../internals/src/utils/mapObjectValues.ts", "../../internals/src/utils/max.ts", "../../internals/src/utils/setClassName.ts", "../../internals/src/warnOnce.ts", "../src/runtime/utils/date.ts", "../src/runtime/utils/decimalJsLike.ts", "../src/runtime/core/errorRendering/throwValidationException.ts", "../../dmmf/src/index.ts", "../../dmmf/src/convert.ts", "../../dmmf/src/dmmf.ts", "../src/runtime/utils/createErrorMessageWithContext.ts", "../src/runtime/utils/SourceFileSlice.ts", "../src/runtime/highlight/theme.ts", "../src/runtime/highlight/prism.ts", "../src/runtime/highlight/highlight.ts", "../src/runtime/utils/dedent.ts", "../src/runtime/core/errorRendering/applyValidationError.ts", "../src/runtime/core/errorRendering/applyUnionError.ts", "../src/runtime/core/errorRendering/ObjectFieldSuggestion.ts", "../../ts-builders/src/index.ts", "../../ts-builders/src/Writer.ts", "../src/runtime/core/errorRendering/ArrayField.ts", "../src/runtime/core/errorRendering/base.ts", "../src/runtime/core/errorRendering/FormattedString.ts", "../src/runtime/core/errorRendering/Value.ts", "../src/runtime/core/errorRendering/ArrayValue.ts", "../src/runtime/core/errorRendering/ObjectValue.ts", "../src/runtime/core/errorRendering/ScalarValue.ts", "../src/runtime/core/errorRendering/SuggestionObjectValue.ts", "../src/runtime/core/errorRendering/ArgumentsRenderingTree.ts", "../src/runtime/core/model/FieldRef.ts", "../src/runtime/core/errorRendering/ObjectField.ts", "../src/runtime/core/model/utils/dmmfToJSModelName.ts", "../src/runtime/core/extensions/resultUtils.ts", "../src/runtime/core/extensions/MergedExtensionsList.ts", "../src/runtime/core/model/Param.ts", "../src/runtime/core/types/exported/Skip.ts", "../src/runtime/core/runtimeDataModel.ts", "../src/runtime/core/types/exported/TypedSql.ts", "../src/runtime/getPrismaClient.ts", "../src/runtime/core/compositeProxy/addObjectProperties.ts", "../src/runtime/core/compositeProxy/addProperty.ts", "../src/runtime/core/compositeProxy/cacheProperties.ts", "../src/runtime/core/model/utils/defaultProxyHandlers.ts", "../src/runtime/core/compositeProxy/createCompositeProxy.ts", "../src/runtime/core/compositeProxy/removeProperties.ts", "../src/runtime/core/errorRendering/prettyPrintArguments.ts", "../../../node_modules/.pnpm/stacktrace-parser@0.1.11/node_modules/stacktrace-parser/dist/stack-trace-parser.esm.js", "../src/runtime/utils/CallSite.ts", "../src/runtime/core/model/aggregates/utils/aggregateMap.ts", "../src/runtime/core/model/aggregates/aggregate.ts", "../src/runtime/core/model/aggregates/count.ts", "../src/runtime/core/model/aggregates/groupBy.ts", "../src/runtime/core/model/applyAggregates.ts", "../src/runtime/core/model/applyFieldsProxy.ts", "../src/runtime/utils/deep-set.ts", "../src/runtime/core/model/applyFluent.ts", "../src/runtime/core/model/applyModel.ts", "../src/runtime/core/model/utils/jsToDMMFModelName.ts", "../src/runtime/core/model/applyModelsAndClientExtensions.ts", "../src/runtime/core/extensions/$extends.ts", "../src/runtime/core/extensions/applyResultExtensions.ts", "../src/runtime/core/extensions/visitQueryResult.ts", "../src/runtime/core/extensions/applyAllResultExtensions.ts", "../src/runtime/utils/deepCloneArgs.ts", "../src/runtime/core/types/exported/itxClientDenyList.ts", "../src/runtime/core/extensions/applyQueryExtensions.ts", "../../client-engine-runtime/src/json-protocol.ts", "../../client-engine-runtime/src/utils.ts", "../../driver-adapter-utils/src/error.ts", "../../driver-adapter-utils/src/const.ts", "../../client-engine-runtime/src/user-facing-error.ts", "../../client-engine-runtime/src/batch.ts", "../../client-engine-runtime/src/interpreter/data-mapper.ts", "../../../node_modules/.pnpm/klona@2.0.6/node_modules/klona/dist/index.mjs", "../../client-engine-runtime/src/sql-commenter.ts", "../../../node_modules/.pnpm/@opentelemetry+api@1.9.0/node_modules/@opentelemetry/api/src/trace/span_kind.ts", "../../client-engine-runtime/src/tracing.ts", "../../../node_modules/.pnpm/@bugsnag+cuid@3.2.1/node_modules/@bugsnag/cuid/lib/pad.mjs", "../../../node_modules/.pnpm/@bugsnag+cuid@3.2.1/node_modules/@bugsnag/cuid/lib/fingerprint.mjs", "../../../node_modules/.pnpm/@bugsnag+cuid@3.2.1/node_modules/@bugsnag/cuid/lib/is-cuid.mjs", "../../../node_modules/.pnpm/@bugsnag+cuid@3.2.1/node_modules/@bugsnag/cuid/lib/cuid.mjs", "../../../node_modules/.pnpm/@bugsnag+cuid@3.2.1/node_modules/@bugsnag/cuid/index.esm.mjs", "../../client-engine-runtime/src/interpreter/generators.ts", "../../../node_modules/.pnpm/nanoid@5.1.5/node_modules/nanoid/index.js", "../../../node_modules/.pnpm/nanoid@5.1.5/node_modules/nanoid/url-alphabet/index.js", "../../../node_modules/.pnpm/ulid@3.0.0/node_modules/ulid/dist/node/index.js", "../../../node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm/stringify.js", "../../../node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm/rng.js", "../../../node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm/native.js", "../../../node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm/v4.js", "../../../node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm/v7.js", "../../client-engine-runtime/src/interpreter/in-memory-processing.ts", "../../client-engine-runtime/src/query-plan.ts", "../../client-engine-runtime/src/interpreter/render-query.ts", "../../client-engine-runtime/src/interpreter/serialize-sql.ts", "../../client-engine-runtime/src/interpreter/validation.ts", "../../client-engine-runtime/src/interpreter/query-interpreter.ts", "../../client-engine-runtime/src/crypto.ts", "../../client-engine-runtime/src/web-platform.ts", "../../client-engine-runtime/src/transaction-manager/transaction-manager-error.ts", "../../client-engine-runtime/src/transaction-manager/transaction-manager.ts", "../src/runtime/core/engines/client/ClientEngine.ts", "../../param-graph/src/serialization.ts", "../../param-graph/src/param-graph.ts", "../package.json", "../src/runtime/utils/deserializeRawParameters.ts", "../src/runtime/core/engines/common/utils/getBatchRequestPayload.ts", "../src/runtime/core/engines/common/utils/maskQuery.ts", "../src/runtime/core/engines/common/utils/normalizeLogs.ts", "../src/runtime/core/engines/common/utils/util.ts", "../src/runtime/core/engines/common/utils/getErrorMessageWithLink.ts", "../src/runtime/core/engines/client/LocalExecutor.ts", "../src/runtime/core/engines/client/parameterization/classify.ts", "../src/runtime/core/engines/client/parameterization/parameterize.ts", "../src/runtime/core/engines/client/QueryPlanCache.ts", "../src/runtime/core/engines/client/RemoteExecutor.ts", "../../../node_modules/.pnpm/cookie-es@2.0.0/node_modules/cookie-es/dist/index.mjs", "../src/runtime/core/errors/PrismaClientError.ts", "../src/runtime/core/engines/accelerate/errors/accelerate-error.ts", "../src/runtime/core/engines/accelerate/errors/utils/set-retryable.ts", "../src/runtime/core/engines/accelerate/errors/invalid-datasource-error.ts", "../src/runtime/core/engines/accelerate/getUrlAndApiKey.ts", "../src/runtime/core/engines/accelerate/HeaderBuilder.ts", "../src/runtime/core/engines/client/utils/engine-timestamp.ts", "../src/runtime/core/engines/client/WasmQueryCompilerLoader.ts", "../src/runtime/core/init/getEngineInstance.ts", "../src/runtime/core/raw-query/rawCommandArgsMapper.ts", "../src/runtime/core/raw-query/rawQueryArgsMapper.ts", "../src/runtime/utils/mssqlPreparedStatement.ts", "../src/runtime/utils/serializeRawParameters.ts", "../src/runtime/core/request/createPrismaPromise.ts", "../../instrumentation-contract/package.json", "../../instrumentation-contract/src/global.ts", "../src/runtime/core/tracing/TracingHelper.ts", "../src/runtime/core/transaction/utils/createLockCountPromise.ts", "../src/runtime/getLogLevel.ts", "../src/runtime/RequestHandler.ts", "../src/runtime/core/jsonProtocol/getBatchId.ts", "../src/runtime/core/jsonProtocol/isWrite.ts", "../src/runtime/DataLoader.ts", "../src/runtime/utils/deserializeRawResults.ts", "../src/runtime/utils/clientVersion.ts", "../src/runtime/utils/validatePrismaClientOptions.ts", "../src/runtime/core/errors/PrismaClientConstructorValidationError.ts", "../src/runtime/utils/waitForBatch.ts", "../src/runtime/strictEnum.ts", "../src/runtime/utils/getRuntime.ts", "../src/runtime/index.ts"],
|
|
4
|
-
"sourcesContent": ["{\n \"name\": \"@prisma/engines-version\",\n \"version\": \"7.4.0-8.534ac5c12b9088d160899554cc8c11039ffb9738\",\n \"main\": \"index.js\",\n \"types\": \"index.d.ts\",\n \"license\": \"Apache-2.0\",\n \"author\": \"Tim Suchanek <suchanek@prisma.io>\",\n \"prisma\": {\n \"enginesVersion\": \"534ac5c12b9088d160899554cc8c11039ffb9738\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/prisma/engines-wrapper.git\",\n \"directory\": \"packages/engines-version\"\n },\n \"devDependencies\": {\n \"@types/node\": \"18.19.76\",\n \"typescript\": \"4.9.5\"\n },\n \"files\": [\n \"index.js\",\n \"index.d.ts\"\n ],\n \"scripts\": {\n \"build\": \"tsc -d\"\n }\n}", "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.enginesVersion = void 0;\nexports.enginesVersion = require('./package.json').prisma.enginesVersion;\n//# sourceMappingURL=index.js.map", "'use strict';\nmodule.exports = string => {\n\tconst match = string.match(/^[ \\t]*(?=\\S)/gm);\n\n\tif (!match) {\n\t\treturn 0;\n\t}\n\n\treturn match.reduce((r, a) => Math.min(r, a.length), Infinity);\n};\n", "'use strict';\n\nmodule.exports = (string, count = 1, options) => {\n\toptions = {\n\t\tindent: ' ',\n\t\tincludeEmptyLines: false,\n\t\t...options\n\t};\n\n\tif (typeof string !== 'string') {\n\t\tthrow new TypeError(\n\t\t\t`Expected \\`input\\` to be a \\`string\\`, got \\`${typeof string}\\``\n\t\t);\n\t}\n\n\tif (typeof count !== 'number') {\n\t\tthrow new TypeError(\n\t\t\t`Expected \\`count\\` to be a \\`number\\`, got \\`${typeof count}\\``\n\t\t);\n\t}\n\n\tif (typeof options.indent !== 'string') {\n\t\tthrow new TypeError(\n\t\t\t`Expected \\`options.indent\\` to be a \\`string\\`, got \\`${typeof options.indent}\\``\n\t\t);\n\t}\n\n\tif (count === 0) {\n\t\treturn string;\n\t}\n\n\tconst regex = options.includeEmptyLines ? /^/gm : /^(?!\\s*$)/gm;\n\n\treturn string.replace(regex, options.indent.repeat(count));\n};\n", "'use strict';\n\nmodule.exports = (options = {}) => {\n\tlet repoUrl;\n\tif (options.repoUrl) {\n\t\trepoUrl = options.repoUrl;\n\t} else if (options.user && options.repo) {\n\t\trepoUrl = `https://github.com/${options.user}/${options.repo}`;\n\t} else {\n\t\tthrow new Error('You need to specify either the `repoUrl` option or both the `user` and `repo` options');\n\t}\n\n\tconst url = new URL(`${repoUrl}/issues/new`);\n\n\tconst types = [\n\t\t'body',\n\t\t'title',\n\t\t'labels',\n\t\t'template',\n\t\t'milestone',\n\t\t'assignee',\n\t\t'projects'\n\t];\n\n\tfor (const type of types) {\n\t\tlet value = options[type];\n\t\tif (value === undefined) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tif (type === 'labels' || type === 'projects') {\n\t\t\tif (!Array.isArray(value)) {\n\t\t\t\tthrow new TypeError(`The \\`${type}\\` option should be an array`);\n\t\t\t}\n\n\t\t\tvalue = value.join(',');\n\t\t}\n\n\t\turl.searchParams.set(type, value);\n\t}\n\n\treturn url.toString();\n};\n\n// TODO: Remove this for the next major release\nmodule.exports.default = module.exports;\n", "'use strict';\nmodule.exports = (function()\n{\n function _min(d0, d1, d2, bx, ay)\n {\n return d0 < d1 || d2 < d1\n ? d0 > d2\n ? d2 + 1\n : d0 + 1\n : bx === ay\n ? d1\n : d1 + 1;\n }\n\n return function(a, b)\n {\n if (a === b) {\n return 0;\n }\n\n if (a.length > b.length) {\n var tmp = a;\n a = b;\n b = tmp;\n }\n\n var la = a.length;\n var lb = b.length;\n\n while (la > 0 && (a.charCodeAt(la - 1) === b.charCodeAt(lb - 1))) {\n la--;\n lb--;\n }\n\n var offset = 0;\n\n while (offset < la && (a.charCodeAt(offset) === b.charCodeAt(offset))) {\n offset++;\n }\n\n la -= offset;\n lb -= offset;\n\n if (la === 0 || lb < 3) {\n return lb;\n }\n\n var x = 0;\n var y;\n var d0;\n var d1;\n var d2;\n var d3;\n var dd;\n var dy;\n var ay;\n var bx0;\n var bx1;\n var bx2;\n var bx3;\n\n var vector = [];\n\n for (y = 0; y < la; y++) {\n vector.push(y + 1);\n vector.push(a.charCodeAt(offset + y));\n }\n\n var len = vector.length - 1;\n\n for (; x < lb - 3;) {\n bx0 = b.charCodeAt(offset + (d0 = x));\n bx1 = b.charCodeAt(offset + (d1 = x + 1));\n bx2 = b.charCodeAt(offset + (d2 = x + 2));\n bx3 = b.charCodeAt(offset + (d3 = x + 3));\n dd = (x += 4);\n for (y = 0; y < len; y += 2) {\n dy = vector[y];\n ay = vector[y + 1];\n d0 = _min(dy, d0, d1, bx0, ay);\n d1 = _min(d0, d1, d2, bx1, ay);\n d2 = _min(d1, d2, d3, bx2, ay);\n dd = _min(d2, d3, dd, bx3, ay);\n vector[y] = dd;\n d3 = d2;\n d2 = d1;\n d1 = d0;\n d0 = dy;\n }\n }\n\n for (; x < lb;) {\n bx0 = b.charCodeAt(offset + (d0 = x));\n dd = ++x;\n for (y = 0; y < len; y += 2) {\n dy = vector[y];\n vector[y] = dd = _min(dy, d0, dd, bx0, vector[y + 1]);\n d0 = dy;\n }\n }\n\n return dd;\n };\n})();\n\n", "import { BasicBuilder } from './BasicBuilder'\nimport type { KeyType } from './KeyType'\nimport { Writer } from './Writer'\n\nexport abstract class TypeBuilder implements BasicBuilder {\n // TODO(@SevInf): this should be replaced with precedence system that would\n // automatically add parenthesis where they are needed\n needsParenthesisWhenIndexed = false\n needsParenthesisInKeyof = false\n needsParenthesisInUnion = false\n needsParenthesisInIntersection = false\n\n abstract write(writer: Writer): void\n\n subKey(key: string): KeyType {\n // TODO: since we translating ESM to CommonJS during bundling, we\n // can't handle circular dependencies the same way ESM does. We have to delay KeyType import\n // to resolve it. Once we stop doing this, we can move this import to top of the file.\n const { KeyType } = require('./KeyType')\n return new KeyType(this, key)\n }\n\n writeIndexed(writer: Writer) {\n if (this.needsParenthesisWhenIndexed) {\n writer.write('(')\n }\n\n writer.write(this)\n\n if (this.needsParenthesisWhenIndexed) {\n writer.write(')')\n }\n }\n}\n", "import { TypeBuilder } from './TypeBuilder'\nimport { Writer } from './Writer'\n\nexport class KeyType extends TypeBuilder {\n constructor(\n public baseType: TypeBuilder,\n public key: string,\n ) {\n super()\n }\n write(writer: Writer): void {\n this.baseType.writeIndexed(writer)\n\n writer.write('[').write(`\"${this.key}\"`).write(']')\n }\n}\n\nexport function keyType(baseType: TypeBuilder, key: string) {\n return new KeyType(baseType, key)\n}\n", "/**\n * Internal assertion helpers.\n * @module\n */\n\n/** Asserts something is positive integer. */\nfunction anumber(n: number): void {\n if (!Number.isSafeInteger(n) || n < 0) throw new Error('positive integer expected, got ' + n);\n}\n\n/** Is number an Uint8Array? Copied from utils for perf. */\nfunction isBytes(a: unknown): a is Uint8Array {\n return a instanceof Uint8Array || (ArrayBuffer.isView(a) && a.constructor.name === 'Uint8Array');\n}\n\n/** Asserts something is Uint8Array. */\nfunction abytes(b: Uint8Array | undefined, ...lengths: number[]): void {\n if (!isBytes(b)) throw new Error('Uint8Array expected');\n if (lengths.length > 0 && !lengths.includes(b.length))\n throw new Error('Uint8Array expected of length ' + lengths + ', got length=' + b.length);\n}\n\n/** Hash interface. */\nexport type Hash = {\n (data: Uint8Array): Uint8Array;\n blockLen: number;\n outputLen: number;\n create: any;\n};\n\n/** Asserts something is hash */\nfunction ahash(h: Hash): void {\n if (typeof h !== 'function' || typeof h.create !== 'function')\n throw new Error('Hash should be wrapped by utils.wrapConstructor');\n anumber(h.outputLen);\n anumber(h.blockLen);\n}\n\n/** Asserts a hash instance has not been destroyed / finished */\nfunction aexists(instance: any, checkFinished = true): void {\n if (instance.destroyed) throw new Error('Hash instance has been destroyed');\n if (checkFinished && instance.finished) throw new Error('Hash#digest() has already been called');\n}\n\n/** Asserts output is properly-sized byte array */\nfunction aoutput(out: any, instance: any): void {\n abytes(out);\n const min = instance.outputLen;\n if (out.length < min) {\n throw new Error('digestInto() expects output buffer of length at least ' + min);\n }\n}\n\nexport { anumber, abytes, ahash, aexists, aoutput };\n", "/**\n * Internal helpers for u64. BigUint64Array is too slow as per 2025, so we implement it using Uint32Array.\n * @todo re-check https://issues.chromium.org/issues/42212588\n * @module\n */\nconst U32_MASK64 = /* @__PURE__ */ BigInt(2 ** 32 - 1);\nconst _32n = /* @__PURE__ */ BigInt(32);\n\nfunction fromBig(\n n: bigint,\n le = false\n): {\n h: number;\n l: number;\n} {\n if (le) return { h: Number(n & U32_MASK64), l: Number((n >> _32n) & U32_MASK64) };\n return { h: Number((n >> _32n) & U32_MASK64) | 0, l: Number(n & U32_MASK64) | 0 };\n}\n\nfunction split(lst: bigint[], le = false): Uint32Array[] {\n let Ah = new Uint32Array(lst.length);\n let Al = new Uint32Array(lst.length);\n for (let i = 0; i < lst.length; i++) {\n const { h, l } = fromBig(lst[i], le);\n [Ah[i], Al[i]] = [h, l];\n }\n return [Ah, Al];\n}\n\nconst toBig = (h: number, l: number): bigint => (BigInt(h >>> 0) << _32n) | BigInt(l >>> 0);\n// for Shift in [0, 32)\nconst shrSH = (h: number, _l: number, s: number): number => h >>> s;\nconst shrSL = (h: number, l: number, s: number): number => (h << (32 - s)) | (l >>> s);\n// Right rotate for Shift in [1, 32)\nconst rotrSH = (h: number, l: number, s: number): number => (h >>> s) | (l << (32 - s));\nconst rotrSL = (h: number, l: number, s: number): number => (h << (32 - s)) | (l >>> s);\n// Right rotate for Shift in (32, 64), NOTE: 32 is special case.\nconst rotrBH = (h: number, l: number, s: number): number => (h << (64 - s)) | (l >>> (s - 32));\nconst rotrBL = (h: number, l: number, s: number): number => (h >>> (s - 32)) | (l << (64 - s));\n// Right rotate for shift===32 (just swaps l&h)\nconst rotr32H = (_h: number, l: number): number => l;\nconst rotr32L = (h: number, _l: number): number => h;\n// Left rotate for Shift in [1, 32)\nconst rotlSH = (h: number, l: number, s: number): number => (h << s) | (l >>> (32 - s));\nconst rotlSL = (h: number, l: number, s: number): number => (l << s) | (h >>> (32 - s));\n// Left rotate for Shift in (32, 64), NOTE: 32 is special case.\nconst rotlBH = (h: number, l: number, s: number): number => (l << (s - 32)) | (h >>> (64 - s));\nconst rotlBL = (h: number, l: number, s: number): number => (h << (s - 32)) | (l >>> (64 - s));\n\n// JS uses 32-bit signed integers for bitwise operations which means we cannot\n// simple take carry out of low bit sum by shift, we need to use division.\nfunction add(\n Ah: number,\n Al: number,\n Bh: number,\n Bl: number\n): {\n h: number;\n l: number;\n} {\n const l = (Al >>> 0) + (Bl >>> 0);\n return { h: (Ah + Bh + ((l / 2 ** 32) | 0)) | 0, l: l | 0 };\n}\n// Addition with more than 2 elements\nconst add3L = (Al: number, Bl: number, Cl: number): number => (Al >>> 0) + (Bl >>> 0) + (Cl >>> 0);\nconst add3H = (low: number, Ah: number, Bh: number, Ch: number): number =>\n (Ah + Bh + Ch + ((low / 2 ** 32) | 0)) | 0;\nconst add4L = (Al: number, Bl: number, Cl: number, Dl: number): number =>\n (Al >>> 0) + (Bl >>> 0) + (Cl >>> 0) + (Dl >>> 0);\nconst add4H = (low: number, Ah: number, Bh: number, Ch: number, Dh: number): number =>\n (Ah + Bh + Ch + Dh + ((low / 2 ** 32) | 0)) | 0;\nconst add5L = (Al: number, Bl: number, Cl: number, Dl: number, El: number): number =>\n (Al >>> 0) + (Bl >>> 0) + (Cl >>> 0) + (Dl >>> 0) + (El >>> 0);\nconst add5H = (low: number, Ah: number, Bh: number, Ch: number, Dh: number, Eh: number): number =>\n (Ah + Bh + Ch + Dh + Eh + ((low / 2 ** 32) | 0)) | 0;\n\n// prettier-ignore\nexport {\n fromBig, split, toBig,\n shrSH, shrSL,\n rotrSH, rotrSL, rotrBH, rotrBL,\n rotr32H, rotr32L,\n rotlSH, rotlSL, rotlBH, rotlBL,\n add, add3L, add3H, add4L, add4H, add5H, add5L,\n};\n// prettier-ignore\nconst u64: { fromBig: typeof fromBig; split: typeof split; toBig: (h: number, l: number) => bigint; shrSH: (h: number, _l: number, s: number) => number; shrSL: (h: number, l: number, s: number) => number; rotrSH: (h: number, l: number, s: number) => number; rotrSL: (h: number, l: number, s: number) => number; rotrBH: (h: number, l: number, s: number) => number; rotrBL: (h: number, l: number, s: number) => number; rotr32H: (_h: number, l: number) => number; rotr32L: (h: number, _l: number) => number; rotlSH: (h: number, l: number, s: number) => number; rotlSL: (h: number, l: number, s: number) => number; rotlBH: (h: number, l: number, s: number) => number; rotlBL: (h: number, l: number, s: number) => number; add: typeof add; add3L: (Al: number, Bl: number, Cl: number) => number; add3H: (low: number, Ah: number, Bh: number, Ch: number) => number; add4L: (Al: number, Bl: number, Cl: number, Dl: number) => number; add4H: (low: number, Ah: number, Bh: number, Ch: number, Dh: number) => number; add5H: (low: number, Ah: number, Bh: number, Ch: number, Dh: number, Eh: number) => number; add5L: (Al: number, Bl: number, Cl: number, Dl: number, El: number) => number; } = {\n fromBig, split, toBig,\n shrSH, shrSL,\n rotrSH, rotrSL, rotrBH, rotrBL,\n rotr32H, rotr32L,\n rotlSH, rotlSL, rotlBH, rotlBL,\n add, add3L, add3H, add4L, add4H, add5H, add5L,\n};\nexport default u64;\n", "/**\n * Internal webcrypto alias.\n * We prefer WebCrypto aka globalThis.crypto, which exists in node.js 16+.\n * Falls back to Node.js built-in crypto for Node.js <=v14.\n * See utils.ts for details.\n * @module\n */\n// @ts-ignore\nimport * as nc from 'node:crypto';\nexport const crypto: any =\n nc && typeof nc === 'object' && 'webcrypto' in nc\n ? (nc.webcrypto as any)\n : nc && typeof nc === 'object' && 'randomBytes' in nc\n ? nc\n : undefined;\n", "/**\n * Utilities for hex, bytes, CSPRNG.\n * @module\n */\n/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */\n\n// We use WebCrypto aka globalThis.crypto, which exists in browsers and node.js 16+.\n// node.js versions earlier than v19 don't declare it in global scope.\n// For node.js, package.json#exports field mapping rewrites import\n// from `crypto` to `cryptoNode`, which imports native module.\n// Makes the utils un-importable in browsers without a bundler.\n// Once node.js 18 is deprecated (2025-04-30), we can just drop the import.\nimport { crypto } from '@noble/hashes/crypto';\nimport { abytes } from './_assert.js';\n// export { isBytes } from './_assert.js';\n// We can't reuse isBytes from _assert, because somehow this causes huge perf issues\nexport function isBytes(a: unknown): a is Uint8Array {\n return a instanceof Uint8Array || (ArrayBuffer.isView(a) && a.constructor.name === 'Uint8Array');\n}\n\n// prettier-ignore\nexport type TypedArray = Int8Array | Uint8ClampedArray | Uint8Array |\n Uint16Array | Int16Array | Uint32Array | Int32Array;\n\n// Cast array to different type\nexport function u8(arr: TypedArray): Uint8Array {\n return new Uint8Array(arr.buffer, arr.byteOffset, arr.byteLength);\n}\nexport function u32(arr: TypedArray): Uint32Array {\n return new Uint32Array(arr.buffer, arr.byteOffset, Math.floor(arr.byteLength / 4));\n}\n\n// Cast array to view\nexport function createView(arr: TypedArray): DataView {\n return new DataView(arr.buffer, arr.byteOffset, arr.byteLength);\n}\n\n/** The rotate right (circular right shift) operation for uint32 */\nexport function rotr(word: number, shift: number): number {\n return (word << (32 - shift)) | (word >>> shift);\n}\n/** The rotate left (circular left shift) operation for uint32 */\nexport function rotl(word: number, shift: number): number {\n return (word << shift) | ((word >>> (32 - shift)) >>> 0);\n}\n\n/** Is current platform little-endian? Most are. Big-Endian platform: IBM */\nexport const isLE: boolean = /* @__PURE__ */ (() =>\n new Uint8Array(new Uint32Array([0x11223344]).buffer)[0] === 0x44)();\n// The byte swap operation for uint32\nexport function byteSwap(word: number): number {\n return (\n ((word << 24) & 0xff000000) |\n ((word << 8) & 0xff0000) |\n ((word >>> 8) & 0xff00) |\n ((word >>> 24) & 0xff)\n );\n}\n/** Conditionally byte swap if on a big-endian platform */\nexport const byteSwapIfBE: (n: number) => number = isLE\n ? (n: number) => n\n : (n: number) => byteSwap(n);\n\n/** In place byte swap for Uint32Array */\nexport function byteSwap32(arr: Uint32Array): void {\n for (let i = 0; i < arr.length; i++) {\n arr[i] = byteSwap(arr[i]);\n }\n}\n\n// Array where index 0xf0 (240) is mapped to string 'f0'\nconst hexes = /* @__PURE__ */ Array.from({ length: 256 }, (_, i) =>\n i.toString(16).padStart(2, '0')\n);\n/**\n * Convert byte array to hex string.\n * @example bytesToHex(Uint8Array.from([0xca, 0xfe, 0x01, 0x23])) // 'cafe0123'\n */\nexport function bytesToHex(bytes: Uint8Array): string {\n abytes(bytes);\n // pre-caching improves the speed 6x\n let hex = '';\n for (let i = 0; i < bytes.length; i++) {\n hex += hexes[bytes[i]];\n }\n return hex;\n}\n\n// We use optimized technique to convert hex string to byte array\nconst asciis = { _0: 48, _9: 57, A: 65, F: 70, a: 97, f: 102 } as const;\nfunction asciiToBase16(ch: number): number | undefined {\n if (ch >= asciis._0 && ch <= asciis._9) return ch - asciis._0; // '2' => 50-48\n if (ch >= asciis.A && ch <= asciis.F) return ch - (asciis.A - 10); // 'B' => 66-(65-10)\n if (ch >= asciis.a && ch <= asciis.f) return ch - (asciis.a - 10); // 'b' => 98-(97-10)\n return;\n}\n\n/**\n * Convert hex string to byte array.\n * @example hexToBytes('cafe0123') // Uint8Array.from([0xca, 0xfe, 0x01, 0x23])\n */\nexport function hexToBytes(hex: string): Uint8Array {\n if (typeof hex !== 'string') throw new Error('hex string expected, got ' + typeof hex);\n const hl = hex.length;\n const al = hl / 2;\n if (hl % 2) throw new Error('hex string expected, got unpadded hex of length ' + hl);\n const array = new Uint8Array(al);\n for (let ai = 0, hi = 0; ai < al; ai++, hi += 2) {\n const n1 = asciiToBase16(hex.charCodeAt(hi));\n const n2 = asciiToBase16(hex.charCodeAt(hi + 1));\n if (n1 === undefined || n2 === undefined) {\n const char = hex[hi] + hex[hi + 1];\n throw new Error('hex string expected, got non-hex character \"' + char + '\" at index ' + hi);\n }\n array[ai] = n1 * 16 + n2; // multiply first octet, e.g. 'a3' => 10*16+3 => 160 + 3 => 163\n }\n return array;\n}\n\n/**\n * There is no setImmediate in browser and setTimeout is slow.\n * Call of async fn will return Promise, which will be fullfiled only on\n * next scheduler queue processing step and this is exactly what we need.\n */\nexport const nextTick = async (): Promise<void> => {};\n\n/** Returns control to thread each 'tick' ms to avoid blocking. */\nexport async function asyncLoop(\n iters: number,\n tick: number,\n cb: (i: number) => void\n): Promise<void> {\n let ts = Date.now();\n for (let i = 0; i < iters; i++) {\n cb(i);\n // Date.now() is not monotonic, so in case if clock goes backwards we return return control too\n const diff = Date.now() - ts;\n if (diff >= 0 && diff < tick) continue;\n await nextTick();\n ts += diff;\n }\n}\n\n// Global symbols in both browsers and Node.js since v11\n// See https://github.com/microsoft/TypeScript/issues/31535\ndeclare const TextEncoder: any;\n\n/**\n * Convert JS string to byte array.\n * @example utf8ToBytes('abc') // new Uint8Array([97, 98, 99])\n */\nexport function utf8ToBytes(str: string): Uint8Array {\n if (typeof str !== 'string') throw new Error('utf8ToBytes expected string, got ' + typeof str);\n return new Uint8Array(new TextEncoder().encode(str)); // https://bugzil.la/1681809\n}\n\n/** Accepted input of hash functions. Strings are converted to byte arrays. */\nexport type Input = Uint8Array | string;\n/**\n * Normalizes (non-hex) string or Uint8Array to Uint8Array.\n * Warning: when Uint8Array is passed, it would NOT get copied.\n * Keep in mind for future mutable operations.\n */\nexport function toBytes(data: Input): Uint8Array {\n if (typeof data === 'string') data = utf8ToBytes(data);\n abytes(data);\n return data;\n}\n\n/**\n * Copies several Uint8Arrays into one.\n */\nexport function concatBytes(...arrays: Uint8Array[]): Uint8Array {\n let sum = 0;\n for (let i = 0; i < arrays.length; i++) {\n const a = arrays[i];\n abytes(a);\n sum += a.length;\n }\n const res = new Uint8Array(sum);\n for (let i = 0, pad = 0; i < arrays.length; i++) {\n const a = arrays[i];\n res.set(a, pad);\n pad += a.length;\n }\n return res;\n}\n\n/** For runtime check if class implements interface */\nexport abstract class Hash<T extends Hash<T>> {\n abstract blockLen: number; // Bytes per block\n abstract outputLen: number; // Bytes in output\n abstract update(buf: Input): this;\n // Writes digest into buf\n abstract digestInto(buf: Uint8Array): void;\n abstract digest(): Uint8Array;\n /**\n * Resets internal state. Makes Hash instance unusable.\n * Reset is impossible for keyed hashes if key is consumed into state. If digest is not consumed\n * by user, they will need to manually call `destroy()` when zeroing is necessary.\n */\n abstract destroy(): void;\n /**\n * Clones hash instance. Unsafe: doesn't check whether `to` is valid. Can be used as `clone()`\n * when no options are passed.\n * Reasons to use `_cloneInto` instead of clone: 1) performance 2) reuse instance => all internal\n * buffers are overwritten => causes buffer overwrite which is used for digest in some cases.\n * There are no guarantees for clean-up because it's impossible in JS.\n */\n abstract _cloneInto(to?: T): T;\n // Safe version that clones internal state\n clone(): T {\n return this._cloneInto();\n }\n}\n\n/**\n * XOF: streaming API to read digest in chunks.\n * Same as 'squeeze' in keccak/k12 and 'seek' in blake3, but more generic name.\n * When hash used in XOF mode it is up to user to call '.destroy' afterwards, since we cannot\n * destroy state, next call can require more bytes.\n */\nexport type HashXOF<T extends Hash<T>> = Hash<T> & {\n xof(bytes: number): Uint8Array; // Read 'bytes' bytes from digest stream\n xofInto(buf: Uint8Array): Uint8Array; // read buf.length bytes from digest stream into buf\n};\n\ntype EmptyObj = {};\nexport function checkOpts<T1 extends EmptyObj, T2 extends EmptyObj>(\n defaults: T1,\n opts?: T2\n): T1 & T2 {\n if (opts !== undefined && {}.toString.call(opts) !== '[object Object]')\n throw new Error('Options should be object or undefined');\n const merged = Object.assign(defaults, opts);\n return merged as T1 & T2;\n}\n\n/** Hash function */\nexport type CHash = ReturnType<typeof wrapConstructor>;\n/** Hash function with output */\nexport type CHashO = ReturnType<typeof wrapConstructorWithOpts>;\n/** XOF with output */\nexport type CHashXO = ReturnType<typeof wrapXOFConstructorWithOpts>;\n\n/** Wraps hash function, creating an interface on top of it */\nexport function wrapConstructor<T extends Hash<T>>(\n hashCons: () => Hash<T>\n): {\n (msg: Input): Uint8Array;\n outputLen: number;\n blockLen: number;\n create(): Hash<T>;\n} {\n const hashC = (msg: Input): Uint8Array => hashCons().update(toBytes(msg)).digest();\n const tmp = hashCons();\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = () => hashCons();\n return hashC;\n}\n\nexport function wrapConstructorWithOpts<H extends Hash<H>, T extends Object>(\n hashCons: (opts?: T) => Hash<H>\n): {\n (msg: Input, opts?: T): Uint8Array;\n outputLen: number;\n blockLen: number;\n create(opts: T): Hash<H>;\n} {\n const hashC = (msg: Input, opts?: T): Uint8Array => hashCons(opts).update(toBytes(msg)).digest();\n const tmp = hashCons({} as T);\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = (opts: T) => hashCons(opts);\n return hashC;\n}\n\nexport function wrapXOFConstructorWithOpts<H extends HashXOF<H>, T extends Object>(\n hashCons: (opts?: T) => HashXOF<H>\n): {\n (msg: Input, opts?: T): Uint8Array;\n outputLen: number;\n blockLen: number;\n create(opts: T): HashXOF<H>;\n} {\n const hashC = (msg: Input, opts?: T): Uint8Array => hashCons(opts).update(toBytes(msg)).digest();\n const tmp = hashCons({} as T);\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = (opts: T) => hashCons(opts);\n return hashC;\n}\n\n/** Cryptographically secure PRNG. Uses internal OS-level `crypto.getRandomValues`. */\nexport function randomBytes(bytesLength = 32): Uint8Array {\n if (crypto && typeof crypto.getRandomValues === 'function') {\n return crypto.getRandomValues(new Uint8Array(bytesLength));\n }\n // Legacy Node.js compatibility\n if (crypto && typeof crypto.randomBytes === 'function') {\n return crypto.randomBytes(bytesLength);\n }\n throw new Error('crypto.getRandomValues must be defined');\n}\n", "/**\n * SHA3 (keccak) hash function, based on a new \"Sponge function\" design.\n * Different from older hashes, the internal state is bigger than output size.\n *\n * Check out [FIPS-202](https://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.202.pdf),\n * [Website](https://keccak.team/keccak.html),\n * [the differences between SHA-3 and Keccak](https://crypto.stackexchange.com/questions/15727/what-are-the-key-differences-between-the-draft-sha-3-standard-and-the-keccak-sub).\n *\n * Check out `sha3-addons` module for cSHAKE, k12, and others.\n * @module\n */\nimport { abytes, aexists, anumber, aoutput } from './_assert.js';\nimport { rotlBH, rotlBL, rotlSH, rotlSL, split } from './_u64.js';\nimport {\n byteSwap32,\n Hash,\n isLE,\n toBytes,\n u32,\n wrapConstructor,\n wrapXOFConstructorWithOpts,\n type CHash,\n type CHashXO,\n type HashXOF,\n type Input,\n} from './utils.js';\n\n// Various per round constants calculations\nconst SHA3_PI: number[] = [];\nconst SHA3_ROTL: number[] = [];\nconst _SHA3_IOTA: bigint[] = [];\nconst _0n = /* @__PURE__ */ BigInt(0);\nconst _1n = /* @__PURE__ */ BigInt(1);\nconst _2n = /* @__PURE__ */ BigInt(2);\nconst _7n = /* @__PURE__ */ BigInt(7);\nconst _256n = /* @__PURE__ */ BigInt(256);\nconst _0x71n = /* @__PURE__ */ BigInt(0x71);\nfor (let round = 0, R = _1n, x = 1, y = 0; round < 24; round++) {\n // Pi\n [x, y] = [y, (2 * x + 3 * y) % 5];\n SHA3_PI.push(2 * (5 * y + x));\n // Rotational\n SHA3_ROTL.push((((round + 1) * (round + 2)) / 2) % 64);\n // Iota\n let t = _0n;\n for (let j = 0; j < 7; j++) {\n R = ((R << _1n) ^ ((R >> _7n) * _0x71n)) % _256n;\n if (R & _2n) t ^= _1n << ((_1n << /* @__PURE__ */ BigInt(j)) - _1n);\n }\n _SHA3_IOTA.push(t);\n}\nconst [SHA3_IOTA_H, SHA3_IOTA_L] = /* @__PURE__ */ split(_SHA3_IOTA, true);\n\n// Left rotation (without 0, 32, 64)\nconst rotlH = (h: number, l: number, s: number) => (s > 32 ? rotlBH(h, l, s) : rotlSH(h, l, s));\nconst rotlL = (h: number, l: number, s: number) => (s > 32 ? rotlBL(h, l, s) : rotlSL(h, l, s));\n\n/** `keccakf1600` internal function, additionally allows to adjust round count. */\nexport function keccakP(s: Uint32Array, rounds: number = 24): void {\n const B = new Uint32Array(5 * 2);\n // NOTE: all indices are x2 since we store state as u32 instead of u64 (bigints to slow in js)\n for (let round = 24 - rounds; round < 24; round++) {\n // Theta \u03B8\n for (let x = 0; x < 10; x++) B[x] = s[x] ^ s[x + 10] ^ s[x + 20] ^ s[x + 30] ^ s[x + 40];\n for (let x = 0; x < 10; x += 2) {\n const idx1 = (x + 8) % 10;\n const idx0 = (x + 2) % 10;\n const B0 = B[idx0];\n const B1 = B[idx0 + 1];\n const Th = rotlH(B0, B1, 1) ^ B[idx1];\n const Tl = rotlL(B0, B1, 1) ^ B[idx1 + 1];\n for (let y = 0; y < 50; y += 10) {\n s[x + y] ^= Th;\n s[x + y + 1] ^= Tl;\n }\n }\n // Rho (\u03C1) and Pi (\u03C0)\n let curH = s[2];\n let curL = s[3];\n for (let t = 0; t < 24; t++) {\n const shift = SHA3_ROTL[t];\n const Th = rotlH(curH, curL, shift);\n const Tl = rotlL(curH, curL, shift);\n const PI = SHA3_PI[t];\n curH = s[PI];\n curL = s[PI + 1];\n s[PI] = Th;\n s[PI + 1] = Tl;\n }\n // Chi (\u03C7)\n for (let y = 0; y < 50; y += 10) {\n for (let x = 0; x < 10; x++) B[x] = s[y + x];\n for (let x = 0; x < 10; x++) s[y + x] ^= ~B[(x + 2) % 10] & B[(x + 4) % 10];\n }\n // Iota (\u03B9)\n s[0] ^= SHA3_IOTA_H[round];\n s[1] ^= SHA3_IOTA_L[round];\n }\n B.fill(0);\n}\n\n/** Keccak sponge function. */\nexport class Keccak extends Hash<Keccak> implements HashXOF<Keccak> {\n protected state: Uint8Array;\n protected pos = 0;\n protected posOut = 0;\n protected finished = false;\n protected state32: Uint32Array;\n protected destroyed = false;\n // NOTE: we accept arguments in bytes instead of bits here.\n constructor(\n public blockLen: number,\n public suffix: number,\n public outputLen: number,\n protected enableXOF = false,\n protected rounds: number = 24\n ) {\n super();\n // Can be passed from user as dkLen\n anumber(outputLen);\n // 1600 = 5x5 matrix of 64bit. 1600 bits === 200 bytes\n // 0 < blockLen < 200\n if (0 >= this.blockLen || this.blockLen >= 200)\n throw new Error('Sha3 supports only keccak-f1600 function');\n this.state = new Uint8Array(200);\n this.state32 = u32(this.state);\n }\n protected keccak(): void {\n if (!isLE) byteSwap32(this.state32);\n keccakP(this.state32, this.rounds);\n if (!isLE) byteSwap32(this.state32);\n this.posOut = 0;\n this.pos = 0;\n }\n update(data: Input): this {\n aexists(this);\n const { blockLen, state } = this;\n data = toBytes(data);\n const len = data.length;\n for (let pos = 0; pos < len; ) {\n const take = Math.min(blockLen - this.pos, len - pos);\n for (let i = 0; i < take; i++) state[this.pos++] ^= data[pos++];\n if (this.pos === blockLen) this.keccak();\n }\n return this;\n }\n protected finish(): void {\n if (this.finished) return;\n this.finished = true;\n const { state, suffix, pos, blockLen } = this;\n // Do the padding\n state[pos] ^= suffix;\n if ((suffix & 0x80) !== 0 && pos === blockLen - 1) this.keccak();\n state[blockLen - 1] ^= 0x80;\n this.keccak();\n }\n protected writeInto(out: Uint8Array): Uint8Array {\n aexists(this, false);\n abytes(out);\n this.finish();\n const bufferOut = this.state;\n const { blockLen } = this;\n for (let pos = 0, len = out.length; pos < len; ) {\n if (this.posOut >= blockLen) this.keccak();\n const take = Math.min(blockLen - this.posOut, len - pos);\n out.set(bufferOut.subarray(this.posOut, this.posOut + take), pos);\n this.posOut += take;\n pos += take;\n }\n return out;\n }\n xofInto(out: Uint8Array): Uint8Array {\n // Sha3/Keccak usage with XOF is probably mistake, only SHAKE instances can do XOF\n if (!this.enableXOF) throw new Error('XOF is not possible for this instance');\n return this.writeInto(out);\n }\n xof(bytes: number): Uint8Array {\n anumber(bytes);\n return this.xofInto(new Uint8Array(bytes));\n }\n digestInto(out: Uint8Array): Uint8Array {\n aoutput(out, this);\n if (this.finished) throw new Error('digest() was already called');\n this.writeInto(out);\n this.destroy();\n return out;\n }\n digest(): Uint8Array {\n return this.digestInto(new Uint8Array(this.outputLen));\n }\n destroy(): void {\n this.destroyed = true;\n this.state.fill(0);\n }\n _cloneInto(to?: Keccak): Keccak {\n const { blockLen, suffix, outputLen, rounds, enableXOF } = this;\n to ||= new Keccak(blockLen, suffix, outputLen, enableXOF, rounds);\n to.state32.set(this.state32);\n to.pos = this.pos;\n to.posOut = this.posOut;\n to.finished = this.finished;\n to.rounds = rounds;\n // Suffix can change in cSHAKE\n to.suffix = suffix;\n to.outputLen = outputLen;\n to.enableXOF = enableXOF;\n to.destroyed = this.destroyed;\n return to;\n }\n}\n\nconst gen = (suffix: number, blockLen: number, outputLen: number) =>\n wrapConstructor(() => new Keccak(blockLen, suffix, outputLen));\n\n/** SHA3-224 hash function. */\nexport const sha3_224: CHash = /* @__PURE__ */ gen(0x06, 144, 224 / 8);\n/** SHA3-256 hash function. Different from keccak-256. */\nexport const sha3_256: CHash = /* @__PURE__ */ gen(0x06, 136, 256 / 8);\n/** SHA3-384 hash function. */\nexport const sha3_384: CHash = /* @__PURE__ */ gen(0x06, 104, 384 / 8);\n/** SHA3-512 hash function. */\nexport const sha3_512: CHash = /* @__PURE__ */ gen(0x06, 72, 512 / 8);\n\n/** keccak-224 hash function. */\nexport const keccak_224: CHash = /* @__PURE__ */ gen(0x01, 144, 224 / 8);\n/** keccak-256 hash function. Different from SHA3-256. */\nexport const keccak_256: CHash = /* @__PURE__ */ gen(0x01, 136, 256 / 8);\n/** keccak-384 hash function. */\nexport const keccak_384: CHash = /* @__PURE__ */ gen(0x01, 104, 384 / 8);\n/** keccak-512 hash function. */\nexport const keccak_512: CHash = /* @__PURE__ */ gen(0x01, 72, 512 / 8);\n\nexport type ShakeOpts = { dkLen?: number };\n\nconst genShake = (suffix: number, blockLen: number, outputLen: number) =>\n wrapXOFConstructorWithOpts<HashXOF<Keccak>, ShakeOpts>(\n (opts: ShakeOpts = {}) =>\n new Keccak(blockLen, suffix, opts.dkLen === undefined ? outputLen : opts.dkLen, true)\n );\n\n/** SHAKE128 XOF with 128-bit security. */\nexport const shake128: CHashXO = /* @__PURE__ */ genShake(0x1f, 168, 128 / 8);\n/** SHAKE256 XOF with 256-bit security. */\nexport const shake256: CHashXO = /* @__PURE__ */ genShake(0x1f, 136, 256 / 8);\n", "/* global global, window, module */\nconst { sha3_512: sha3 } = require(\"@noble/hashes/sha3\");\n\nconst defaultLength = 24;\nconst bigLength = 32;\n\nconst createEntropy = (length = 4, random = Math.random) => {\n let entropy = \"\";\n\n while (entropy.length < length) {\n entropy = entropy + Math.floor(random() * 36).toString(36);\n }\n return entropy;\n};\n\n/*\n * Adapted from https://github.com/juanelas/bigint-conversion\n * MIT License Copyright (c) 2018 Juan Hern\u00E1ndez Serrano\n */\nfunction bufToBigInt(buf) {\n let bits = 8n;\n\n let value = 0n;\n for (const i of buf.values()) {\n const bi = BigInt(i);\n value = (value << bits) + bi;\n }\n return value;\n}\n\nconst hash = (input = \"\") => {\n // Drop the first character because it will bias the histogram\n // to the left.\n return bufToBigInt(sha3(input)).toString(36).slice(1);\n};\n\nconst alphabet = Array.from({ length: 26 }, (x, i) =>\n String.fromCharCode(i + 97)\n);\n\nconst randomLetter = (random) =>\n alphabet[Math.floor(random() * alphabet.length)];\n\n/*\nThis is a fingerprint of the host environment. It is used to help\nprevent collisions when generating ids in a distributed system.\nIf no global object is available, you can pass in your own, or fall back\non a random string.\n*/\nconst createFingerprint = ({\n globalObj = typeof global !== \"undefined\"\n ? global\n : typeof window !== \"undefined\"\n ? window\n : {},\n random = Math.random,\n} = {}) => {\n const globals = Object.keys(globalObj).toString();\n const sourceString = globals.length\n ? globals + createEntropy(bigLength, random)\n : createEntropy(bigLength, random);\n\n return hash(sourceString).substring(0, bigLength);\n};\n\nconst createCounter = (count) => () => {\n return count++;\n};\n\n// ~22k hosts before 50% chance of initial counter collision\n// with a remaining counter range of 9.0e+15 in JavaScript.\nconst initialCountMax = 476782367;\n\nconst init = ({\n // Fallback if the user does not pass in a CSPRNG. This should be OK\n // because we don't rely solely on the random number generator for entropy.\n // We also use the host fingerprint, current time, and a session counter.\n random = Math.random,\n counter = createCounter(Math.floor(random() * initialCountMax)),\n length = defaultLength,\n fingerprint = createFingerprint({ random }),\n} = {}) => {\n return function cuid2() {\n const firstLetter = randomLetter(random);\n\n // If we're lucky, the `.toString(36)` calls may reduce hashing rounds\n // by shortening the input to the hash function a little.\n const time = Date.now().toString(36);\n const count = counter().toString(36);\n\n // The salt should be long enough to be globally unique across the full\n // length of the hash. For simplicity, we use the same length as the\n // intended id output.\n const salt = createEntropy(length, random);\n const hashInput = `${time + salt + count + fingerprint}`;\n\n return `${firstLetter + hash(hashInput).substring(1, length)}`;\n };\n};\n\nconst createId = init();\n\nconst isCuid = (id, { minLength = 2, maxLength = bigLength } = {}) => {\n const length = id.length;\n const regex = /^[0-9a-z]+$/;\n\n try {\n if (\n typeof id === \"string\" &&\n length >= minLength &&\n length <= maxLength &&\n regex.test(id)\n )\n return true;\n } finally {\n }\n\n return false;\n};\n\nmodule.exports.getConstants = () => ({ defaultLength, bigLength });\nmodule.exports.init = init;\nmodule.exports.createId = createId;\nmodule.exports.bufToBigInt = bufToBigInt;\nmodule.exports.createCounter = createCounter;\nmodule.exports.createFingerprint = createFingerprint;\nmodule.exports.isCuid = isCuid;\n", "const { createId, init, getConstants, isCuid } = require(\"./src/index\");\n\nmodule.exports.createId = createId;\nmodule.exports.init = init;\nmodule.exports.getConstants = getConstants;\nmodule.exports.isCuid = isCuid;\n", "import { defineExtension } from './defineExtension'\nimport { getExtensionContext } from './getExtensionContext'\n\nexport { defineExtension }\nexport { getExtensionContext }\n", "import { Client } from '../../getPrismaClient'\nimport { ExtensionArgs } from '../types/exported/ExtensionArgs'\n\nexport function defineExtension(ext: ExtensionArgs | ((client: Client) => Client)) {\n if (typeof ext === 'function') {\n return ext\n }\n\n return (client: Client) => client.$extends(ext)\n}\n", "/*\n * Because we use a symbol to store the context, we need to merge the context\n * with the original this type. We manage the context via `getExtensionContext`\n * to circumvent the limitations of `this` inference in TS, while also providing\n * a unified API for context management in generic and non-generic extensions.\n */\n\n/* eslint-disable prettier/prettier */\nexport type Context<T> = T extends { [K: symbol]: { ctx: infer C } }\n ? C &\n T & {\n /**\n * @deprecated Use `$name` instead.\n */\n name?: string\n $name?: string\n $parent?: unknown\n }\n : T & {\n /**\n * @deprecated Use `$name` instead.\n */\n name?: string\n $name?: string\n $parent?: unknown\n }\n\nexport function getExtensionContext<T>(that: T) {\n return that as any as Context<T>\n}\n", "import { validator } from './validator'\n\n/*\n * /!\\ These exports are exposed to the user. Proceed with caution.\n *\n * TODO: Move more hardcoded utils from generation into here\n */\n\nexport { validator }\n", "import { Args, Operation } from '../types/exported/Public'\nimport { Exact } from '../types/exported/Utils'\n\nexport function validator<V>(): <S>(select: Exact<S, V>) => S\nexport function validator<C, M extends Exclude<keyof C, `$${string}`>, O extends keyof C[M] & Operation>(\n client: C,\n model: M,\n operation: O,\n): <S>(select: Exact<S, Args<C[M], O>>) => S\nexport function validator<\n C,\n M extends Exclude<keyof C, `$${string}`>,\n O extends keyof C[M] & Operation,\n P extends keyof Args<C[M], O>,\n>(client: C, model: M, operation: O, prop: P): <S>(select: Exact<S, Args<C[M], O>[P]>) => S\nexport function validator(..._args: any[]) {\n return (args: any) => args\n}\n", "type CacheEntry<V> = {\n value: V\n}\nexport class Cache<K, V> {\n private _map = new Map<K, CacheEntry<V>>()\n\n get(key: K): V | undefined {\n return this._map.get(key)?.value\n }\n\n set(key: K, value: V): void {\n this._map.set(key, { value })\n }\n\n getOrCreate(key: K, create: () => V): V {\n const cached = this._map.get(key)\n if (cached) {\n return cached.value\n }\n const value = create()\n this.set(key, value)\n return value\n }\n}\n", "/**\n * Converts the first character of a word to upper case.\n */\nexport function capitalize<T extends string>(self: T): Capitalize<T> {\n if (self.length === 0) return self as Capitalize<T>\n\n return (self[0].toUpperCase() + self.slice(1)) as Capitalize<T>\n}\n\n/**\n * Converts the first character of a word to lower case.\n */\nexport function uncapitalize<T extends string>(self: T): Uncapitalize<T> {\n return (self.substring(0, 1).toLowerCase() + self.substring(1)) as Uncapitalize<T>\n}\n", "export interface Dictionary<T> {\n [key: string]: T\n}\n\nexport function keyBy<P extends PropertyKey, T extends { [key in P]: string }>(\n collection: readonly T[],\n prop: P,\n): Dictionary<T> {\n const acc: Dictionary<T> = {}\n\n for (const obj of collection) {\n const key = obj[prop]\n acc[key] = obj\n }\n\n return acc\n}\n", "export type LazyProperty<T> = {\n get: () => T\n}\n\nexport function lazyProperty<T>(compute: () => T): LazyProperty<T> {\n let resultContainer: undefined | { value: T }\n\n return {\n get() {\n if (resultContainer) {\n return resultContainer.value\n }\n resultContainer = { value: compute() }\n return resultContainer.value\n },\n }\n}\n", "import type * as DMMF from '@prisma/dmmf'\n\nexport type RuntimeModel = Omit<DMMF.Model, 'name'>\nexport type RuntimeEnum = Omit<DMMF.DatamodelEnum, 'name'>\n\nexport type RuntimeDataModel = {\n readonly models: Record<string, RuntimeModel>\n readonly enums: Record<string, RuntimeEnum>\n readonly types: Record<string, RuntimeModel>\n}\n\nexport type PrunedRuntimeModel = {\n readonly dbName: RuntimeModel['dbName']\n readonly fields: Pick<RuntimeModel['fields'][number], 'name' | 'kind' | 'type' | 'relationName' | 'dbName'>[]\n}\n\nexport type PrunedRuntimeDataModel = {\n readonly models: Record<string, PrunedRuntimeModel>\n readonly enums: {}\n readonly types: {}\n}\n\nexport function dmmfToRuntimeDataModel(dmmfDataModel: DMMF.Datamodel): RuntimeDataModel {\n return {\n models: buildMapForRuntime(dmmfDataModel.models),\n enums: buildMapForRuntime(dmmfDataModel.enums),\n types: buildMapForRuntime(dmmfDataModel.types),\n }\n}\n\n/**\n * Minimal version of the runtime datamodel for the Client to work\n * @param runtimeDataModel\n * @returns\n */\nexport function pruneRuntimeDataModel({ models }: RuntimeDataModel) {\n const prunedModels: PrunedRuntimeDataModel['models'] = {}\n\n for (const modelName of Object.keys(models)) {\n prunedModels[modelName] = { fields: [], dbName: models[modelName].dbName }\n\n for (const { name, kind, type, relationName, dbName } of models[modelName].fields) {\n prunedModels[modelName].fields.push({ name, kind, type, relationName, dbName })\n }\n }\n\n return { models: prunedModels, enums: {}, types: {} }\n}\n\nfunction buildMapForRuntime<T extends { name: string }>(list: readonly T[]): Record<string, Omit<T, 'name'>> {\n const result: Record<string, Omit<T, 'name'>> = {}\n for (const { name, ...rest } of list) {\n result[name] = rest\n }\n return result\n}\n", "import { RuntimeDataModel, RuntimeModel, uncapitalize } from '@prisma/client-common'\nimport { isAnyNull, isDbNull, isJsonNull, ObjectEnumValue } from '@prisma/client-runtime-utils'\nimport { assertNever } from '@prisma/internals'\n\nimport { ErrorFormat } from '../../getPrismaClient'\nimport { CallSite } from '../../utils/CallSite'\nimport { isDate, isValidDate } from '../../utils/date'\nimport { isDecimalJsLike } from '../../utils/decimalJsLike'\nimport {\n JsonArgumentValue,\n JsonFieldSelection,\n JsonQuery,\n JsonQueryAction,\n JsonSelectionSet,\n OutputTypeDescription,\n RawTaggedValue,\n} from '../engines'\nimport { throwValidationException } from '../errorRendering/throwValidationException'\nimport { MergedExtensionsList } from '../extensions/MergedExtensionsList'\nimport { computeEngineSideOmissions, computeEngineSideSelection } from '../extensions/resultUtils'\nimport { isFieldRef } from '../model/FieldRef'\nimport { isParam } from '../model/Param'\nimport { isSkip, Skip } from '../types'\nimport {\n Action,\n JsArgs,\n JsInputValue,\n JsonConvertible,\n Omission,\n RawParameters,\n Selection,\n} from '../types/exported/JsApi'\nimport { ValidationError } from '../types/ValidationError'\n\nconst jsActionToProtocolAction: Record<Action, JsonQueryAction> = {\n findUnique: 'findUnique',\n findUniqueOrThrow: 'findUniqueOrThrow',\n findFirst: 'findFirst',\n findFirstOrThrow: 'findFirstOrThrow',\n findMany: 'findMany',\n count: 'aggregate',\n create: 'createOne',\n createMany: 'createMany',\n createManyAndReturn: 'createManyAndReturn',\n update: 'updateOne',\n updateMany: 'updateMany',\n updateManyAndReturn: 'updateManyAndReturn',\n upsert: 'upsertOne',\n delete: 'deleteOne',\n deleteMany: 'deleteMany',\n executeRaw: 'executeRaw',\n queryRaw: 'queryRaw',\n aggregate: 'aggregate',\n groupBy: 'groupBy',\n runCommandRaw: 'runCommandRaw',\n findRaw: 'findRaw',\n aggregateRaw: 'aggregateRaw',\n}\n\nexport type GlobalOmitOptions = {\n [modelName: string]: {\n [fieldName: string]: boolean\n }\n}\n\nexport type SerializeParams = {\n runtimeDataModel: RuntimeDataModel\n modelName?: string\n action: Action\n args?: JsArgs\n extensions?: MergedExtensionsList\n callsite?: CallSite\n clientMethod: string\n clientVersion: string\n errorFormat: ErrorFormat\n previewFeatures: string[]\n globalOmit?: GlobalOmitOptions\n wrapRawValues?: boolean\n}\n\nconst STRICT_UNDEFINED_ERROR_MESSAGE = 'explicitly `undefined` values are not allowed'\n\nexport function serializeJsonQuery({\n modelName,\n action,\n args,\n runtimeDataModel,\n extensions = MergedExtensionsList.empty(),\n callsite,\n clientMethod,\n errorFormat,\n clientVersion,\n previewFeatures,\n globalOmit,\n wrapRawValues,\n}: SerializeParams): JsonQuery {\n const context = new SerializeContext({\n runtimeDataModel,\n modelName,\n action,\n rootArgs: args,\n callsite,\n extensions,\n selectionPath: [],\n argumentPath: [],\n originalMethod: clientMethod,\n errorFormat,\n clientVersion,\n previewFeatures,\n globalOmit,\n wrapRawValues,\n })\n return {\n modelName,\n action: jsActionToProtocolAction[action],\n query: serializeFieldSelection(args, context),\n }\n}\n\nfunction serializeFieldSelection(\n { select, include, ...args }: JsArgs = {},\n context: SerializeContext,\n): JsonFieldSelection {\n const omit = args.omit\n delete args.omit\n return {\n arguments: serializeArgumentsObject(args, context),\n selection: serializeSelectionSet(select, include, omit, context),\n }\n}\n\nfunction serializeSelectionSet(\n select: Selection | undefined,\n include: Selection | undefined,\n omit: Omission | undefined,\n context: SerializeContext,\n): JsonSelectionSet {\n if (select) {\n if (include) {\n context.throwValidationError({\n kind: 'MutuallyExclusiveFields',\n firstField: 'include',\n secondField: 'select',\n selectionPath: context.getSelectionPath(),\n })\n } else if (omit) {\n context.throwValidationError({\n kind: 'MutuallyExclusiveFields',\n firstField: 'omit',\n secondField: 'select',\n selectionPath: context.getSelectionPath(),\n })\n }\n return createExplicitSelection(select, context)\n }\n\n return createImplicitSelection(context, include, omit)\n}\n\nfunction createImplicitSelection(\n context: SerializeContext,\n include: Selection | undefined,\n omit: Omission | undefined,\n) {\n const selectionSet: JsonSelectionSet = {}\n\n if (context.modelOrType && !context.isRawAction()) {\n selectionSet.$composites = true\n selectionSet.$scalars = true\n }\n\n if (include) {\n addIncludedRelations(selectionSet, include, context)\n }\n\n omitFields(selectionSet, omit, context)\n\n return selectionSet\n}\n\nfunction addIncludedRelations(selectionSet: JsonSelectionSet, include: Selection, context: SerializeContext) {\n for (const [key, value] of Object.entries(include)) {\n if (isSkip(value)) {\n continue\n }\n const nestedContext = context.nestSelection(key)\n validateSelectionForUndefined(value, nestedContext)\n if (value === false || value === undefined) {\n selectionSet[key] = false\n continue\n }\n\n const field = context.findField(key)\n if (field && field.kind !== 'object') {\n context.throwValidationError({\n kind: 'IncludeOnScalar',\n selectionPath: context.getSelectionPath().concat(key),\n outputType: context.getOutputTypeDescription(),\n })\n }\n if (field) {\n selectionSet[key] = serializeFieldSelection(value === true ? {} : value, nestedContext)\n continue\n }\n\n if (value === true) {\n selectionSet[key] = true\n continue\n }\n\n // value is an object, field is unknown\n // this can either be user error (in that case, qe will respond with an error)\n // or virtual field not present on datamodel (like `_count`).\n // Since we don't know which one cast is, we still attempt to serialize selection\n selectionSet[key] = serializeFieldSelection(value, nestedContext)\n }\n}\n\nfunction omitFields(selectionSet: JsonSelectionSet, localOmit: Omission | undefined, context: SerializeContext) {\n const computedFields = context.getComputedFields()\n const combinedOmits = { ...context.getGlobalOmit(), ...localOmit }\n const omitWithComputedFields = computeEngineSideOmissions(combinedOmits, computedFields)\n for (const [key, value] of Object.entries(omitWithComputedFields)) {\n if (isSkip(value)) {\n continue\n }\n validateSelectionForUndefined(value, context.nestSelection(key))\n const field = context.findField(key)\n if (computedFields?.[key] && !field) {\n continue\n }\n selectionSet[key] = !value\n }\n}\n\nfunction createExplicitSelection(select: Selection, context: SerializeContext) {\n const selectionSet: JsonSelectionSet = {}\n const computedFields = context.getComputedFields()\n const selectWithComputedFields = computeEngineSideSelection(select, computedFields)\n\n for (const [key, value] of Object.entries(selectWithComputedFields)) {\n if (isSkip(value)) {\n continue\n }\n const nestedContext = context.nestSelection(key)\n validateSelectionForUndefined(value, nestedContext)\n const field = context.findField(key)\n if (computedFields?.[key] && !field) {\n continue\n }\n if (value === false || value === undefined || isSkip(value)) {\n selectionSet[key] = false\n continue\n }\n if (value === true) {\n if (field?.kind === 'object') {\n selectionSet[key] = serializeFieldSelection({}, nestedContext)\n } else {\n selectionSet[key] = true\n }\n continue\n }\n selectionSet[key] = serializeFieldSelection(value, nestedContext)\n }\n return selectionSet\n}\n\nfunction serializeArgumentsValue(\n jsValue: Exclude<JsInputValue, undefined | Skip>,\n context: SerializeContext,\n): JsonArgumentValue {\n if (jsValue === null) {\n return null\n }\n\n if (typeof jsValue === 'string' || typeof jsValue === 'number' || typeof jsValue === 'boolean') {\n return jsValue\n }\n\n if (typeof jsValue === 'bigint') {\n return { $type: 'BigInt', value: String(jsValue) }\n }\n\n if (isDate(jsValue)) {\n if (isValidDate(jsValue)) {\n return { $type: 'DateTime', value: jsValue.toISOString() }\n } else {\n context.throwValidationError({\n kind: 'InvalidArgumentValue',\n selectionPath: context.getSelectionPath(),\n argumentPath: context.getArgumentPath(),\n argument: {\n name: context.getArgumentName(),\n typeNames: ['Date'],\n },\n underlyingError: 'Provided Date object is invalid',\n })\n }\n }\n\n if (isParam(jsValue)) {\n return { $type: 'Param', value: jsValue.name }\n }\n\n if (isFieldRef(jsValue)) {\n return { $type: 'FieldRef', value: { _ref: jsValue.name, _container: jsValue.modelName } }\n }\n\n if (Array.isArray(jsValue)) {\n return serializeArgumentsArray(jsValue, context)\n }\n\n if (ArrayBuffer.isView(jsValue)) {\n const { buffer, byteOffset, byteLength } = jsValue\n // TODO(perf): get rid of this conversion\n return { $type: 'Bytes', value: Buffer.from(buffer, byteOffset, byteLength).toString('base64') }\n }\n\n if (isRawParameters(jsValue)) {\n return jsValue.values\n }\n\n if (isDecimalJsLike(jsValue)) {\n return { $type: 'Decimal', value: jsValue.toFixed() }\n }\n\n if (jsValue instanceof ObjectEnumValue) {\n if (!isDbNull(jsValue) && !isJsonNull(jsValue) && !isAnyNull(jsValue)) {\n throw new Error('Invalid ObjectEnumValue')\n }\n return { $type: 'Enum', value: jsValue._getName() }\n }\n\n if (isJSONConvertible(jsValue)) {\n return jsValue.toJSON() as JsonArgumentValue\n }\n\n if (typeof jsValue === 'object') {\n return serializeArgumentsObject(jsValue, context)\n }\n\n context.throwValidationError({\n kind: 'InvalidArgumentValue',\n selectionPath: context.getSelectionPath(),\n argumentPath: context.getArgumentPath(),\n argument: {\n name: context.getArgumentName(),\n typeNames: [],\n },\n underlyingError: `We could not serialize ${Object.prototype.toString.call(\n jsValue,\n )} value. Serialize the object to JSON or implement a \".toJSON()\" method on it`,\n })\n}\n\nfunction serializeArgumentsObject(\n object: Record<string, JsInputValue>,\n context: SerializeContext,\n): Record<string, JsonArgumentValue> | RawTaggedValue {\n if (context.shouldWrapRawValues()) {\n if (object['$type']) {\n return { $type: 'Raw', value: object }\n }\n }\n const result: Record<string, JsonArgumentValue> = {}\n for (const key in object) {\n const value = object[key]\n const nestedContext = context.nestArgument(key)\n if (isSkip(value)) {\n continue\n }\n if (value !== undefined) {\n result[key] = serializeArgumentsValue(value, nestedContext)\n } else if (context.isPreviewFeatureOn('strictUndefinedChecks')) {\n context.throwValidationError({\n kind: 'InvalidArgumentValue',\n argumentPath: nestedContext.getArgumentPath(),\n selectionPath: context.getSelectionPath(),\n argument: { name: context.getArgumentName(), typeNames: [] },\n underlyingError: STRICT_UNDEFINED_ERROR_MESSAGE,\n })\n }\n }\n return result\n}\n\nfunction serializeArgumentsArray(array: JsInputValue[], context: SerializeContext): JsonArgumentValue[] {\n const result: JsonArgumentValue[] = []\n for (let i = 0; i < array.length; i++) {\n const itemContext = context.nestArgument(String(i))\n const value = array[i]\n if (value === undefined || isSkip(value)) {\n const valueName = value === undefined ? 'undefined' : `Prisma.skip`\n context.throwValidationError({\n kind: 'InvalidArgumentValue',\n selectionPath: itemContext.getSelectionPath(),\n argumentPath: itemContext.getArgumentPath(),\n argument: {\n name: `${context.getArgumentName()}[${i}]`,\n typeNames: [],\n },\n underlyingError: `Can not use \\`${valueName}\\` value within array. Use \\`null\\` or filter out \\`${valueName}\\` values`,\n })\n }\n result.push(serializeArgumentsValue(value, itemContext))\n }\n return result\n}\n\nfunction isRawParameters(value: JsInputValue): value is RawParameters {\n return typeof value === 'object' && value !== null && value['__prismaRawParameters__'] === true\n}\n\nfunction isJSONConvertible(value: JsInputValue): value is JsonConvertible {\n return typeof value === 'object' && value !== null && typeof value['toJSON'] === 'function'\n}\n\nfunction validateSelectionForUndefined(value: unknown, context: SerializeContext) {\n if (value === undefined && context.isPreviewFeatureOn('strictUndefinedChecks')) {\n context.throwValidationError({\n kind: 'InvalidSelectionValue',\n selectionPath: context.getSelectionPath(),\n underlyingError: STRICT_UNDEFINED_ERROR_MESSAGE,\n })\n }\n}\n\ntype ContextParams = {\n runtimeDataModel: RuntimeDataModel\n originalMethod: string\n rootArgs: JsArgs | undefined\n extensions: MergedExtensionsList\n selectionPath: string[]\n argumentPath: string[]\n modelName?: string\n action: Action\n callsite?: CallSite\n errorFormat: ErrorFormat\n clientVersion: string\n previewFeatures: string[]\n globalOmit?: GlobalOmitOptions\n wrapRawValues?: boolean\n}\n\nclass SerializeContext {\n public readonly modelOrType: RuntimeModel | undefined\n constructor(private params: ContextParams) {\n if (this.params.modelName) {\n // TODO: throw if not found\n this.modelOrType =\n this.params.runtimeDataModel.models[this.params.modelName] ??\n this.params.runtimeDataModel.types[this.params.modelName]\n }\n }\n\n throwValidationError(error: ValidationError): never {\n throwValidationException({\n errors: [error],\n originalMethod: this.params.originalMethod,\n args: this.params.rootArgs ?? {},\n callsite: this.params.callsite,\n errorFormat: this.params.errorFormat,\n clientVersion: this.params.clientVersion,\n globalOmit: this.params.globalOmit,\n })\n }\n\n getSelectionPath() {\n return this.params.selectionPath\n }\n\n getArgumentPath() {\n return this.params.argumentPath\n }\n\n getArgumentName() {\n return this.params.argumentPath[this.params.argumentPath.length - 1]\n }\n\n getOutputTypeDescription(): OutputTypeDescription | undefined {\n if (!this.params.modelName || !this.modelOrType) {\n return undefined\n }\n return {\n name: this.params.modelName,\n fields: this.modelOrType.fields.map((field) => ({\n name: field.name,\n typeName: 'boolean',\n isRelation: field.kind === 'object',\n })),\n }\n }\n\n isRawAction() {\n return ['executeRaw', 'queryRaw', 'runCommandRaw', 'findRaw', 'aggregateRaw'].includes(this.params.action)\n }\n\n isPreviewFeatureOn(previewFeature: string) {\n return this.params.previewFeatures.includes(previewFeature)\n }\n\n shouldWrapRawValues(): boolean {\n return this.params.wrapRawValues ?? false\n }\n\n getComputedFields() {\n if (!this.params.modelName) {\n return undefined\n }\n\n return this.params.extensions.getAllComputedFields(this.params.modelName)\n }\n\n findField(name: string) {\n return this.modelOrType?.fields.find((field) => field.name === name)\n }\n\n nestSelection(fieldName: string) {\n const field = this.findField(fieldName)\n const modelName = field?.kind === 'object' ? field.type : undefined\n\n return new SerializeContext({\n ...this.params,\n modelName,\n selectionPath: this.params.selectionPath.concat(fieldName),\n })\n }\n\n getGlobalOmit(): Record<string, boolean> {\n if (this.params.modelName && this.shouldApplyGlobalOmit()) {\n return this.params.globalOmit?.[uncapitalize(this.params.modelName)] ?? {}\n }\n return {}\n }\n\n shouldApplyGlobalOmit(): boolean {\n switch (this.params.action) {\n case 'findFirst':\n case 'findFirstOrThrow':\n case 'findUniqueOrThrow':\n case 'findMany':\n case 'upsert':\n case 'findUnique':\n case 'createManyAndReturn':\n case 'create':\n case 'update':\n case 'updateManyAndReturn':\n case 'delete':\n return true\n case 'executeRaw':\n case 'aggregateRaw':\n case 'runCommandRaw':\n case 'findRaw':\n case 'createMany':\n case 'deleteMany':\n case 'groupBy':\n case 'updateMany':\n case 'count':\n case 'aggregate':\n case 'queryRaw':\n return false\n default:\n assertNever(this.params.action, 'Unknown action')\n }\n }\n\n nestArgument(fieldName: string) {\n return new SerializeContext({\n ...this.params,\n argumentPath: this.params.argumentPath.concat(fieldName),\n })\n }\n}\n", "let FORCE_COLOR, NODE_DISABLE_COLORS, NO_COLOR, TERM, isTTY=true;\nif (typeof process !== 'undefined') {\n\t({ FORCE_COLOR, NODE_DISABLE_COLORS, NO_COLOR, TERM } = process.env || {});\n\tisTTY = process.stdout && process.stdout.isTTY;\n}\n\nexport const $ = {\n\tenabled: !NODE_DISABLE_COLORS && NO_COLOR == null && TERM !== 'dumb' && (\n\t\tFORCE_COLOR != null && FORCE_COLOR !== '0' || isTTY\n\t)\n}\n\nfunction init(x, y) {\n\tlet rgx = new RegExp(`\\\\x1b\\\\[${y}m`, 'g');\n\tlet open = `\\x1b[${x}m`, close = `\\x1b[${y}m`;\n\n\treturn function (txt) {\n\t\tif (!$.enabled || txt == null) return txt;\n\t\treturn open + (!!~(''+txt).indexOf(close) ? txt.replace(rgx, close + open) : txt) + close;\n\t};\n}\n\n// modifiers\nexport const reset = init(0, 0);\nexport const bold = init(1, 22);\nexport const dim = init(2, 22);\nexport const italic = init(3, 23);\nexport const underline = init(4, 24);\nexport const inverse = init(7, 27);\nexport const hidden = init(8, 28);\nexport const strikethrough = init(9, 29);\n\n// colors\nexport const black = init(30, 39);\nexport const red = init(31, 39);\nexport const green = init(32, 39);\nexport const yellow = init(33, 39);\nexport const blue = init(34, 39);\nexport const magenta = init(35, 39);\nexport const cyan = init(36, 39);\nexport const white = init(37, 39);\nexport const gray = init(90, 39);\nexport const grey = init(90, 39);\n\n// background colors\nexport const bgBlack = init(40, 49);\nexport const bgRed = init(41, 49);\nexport const bgGreen = init(42, 49);\nexport const bgYellow = init(43, 49);\nexport const bgBlue = init(44, 49);\nexport const bgMagenta = init(45, 49);\nexport const bgCyan = init(46, 49);\nexport const bgWhite = init(47, 49);\n", "import * as kleur from 'kleur/colors'\nimport { bold } from 'kleur/colors'\n\nconst MAX_ARGS_HISTORY = 100\nconst COLORS = ['green', 'yellow', 'blue', 'magenta', 'cyan', 'red']\n\nconst argsHistory: [namespace: string, ...unknown[]][] = []\nlet lastTimestamp = Date.now()\nlet lastColor = 0\n\nconst processEnv = typeof process !== 'undefined' ? process.env : {}\n\nglobalThis.DEBUG ??= processEnv.DEBUG ?? ''\nglobalThis.DEBUG_COLORS ??= processEnv.DEBUG_COLORS ? processEnv.DEBUG_COLORS === 'true' : true\n\n/**\n * Top-level utilities to configure the debug module.\n *\n * @example\n * ```ts\n * import Debug from '@prisma/debug'\n * Debug.enable('prisma:client')\n * const debug = Debug('prisma:client')\n * debug('Hello World')\n * ```\n */\nconst topProps = {\n enable(namespace: any) {\n if (typeof namespace === 'string') {\n globalThis.DEBUG = namespace\n }\n },\n disable() {\n const prev = globalThis.DEBUG\n globalThis.DEBUG = ''\n return prev\n },\n // this is the core logic to check if logging should happen or not\n enabled(namespace: string) {\n // these are the namespaces that we are listening to in DEBUG=...\n const listenedNamespaces: string[] = globalThis.DEBUG.split(',').map((s: string) => {\n return s.replace(/[.+?^${}()|[\\]\\\\]/g, '\\\\$&') // escape regex except \"*\"\n })\n\n // we take incoming namespaces and check then against listened\n const isListened = listenedNamespaces.some((listenedNamespace) => {\n if (listenedNamespace === '' || listenedNamespace[0] === '-') return false\n\n return namespace.match(RegExp(listenedNamespace.split('*').join('.*') + '$'))\n })\n\n // we take incoming namespaces and check then against excluded\n const isExcluded = listenedNamespaces.some((listenedNamespace) => {\n if (listenedNamespace === '' || listenedNamespace[0] !== '-') return false\n\n return namespace.match(RegExp(listenedNamespace.slice(1).split('*').join('.*') + '$'))\n })\n\n return isListened && !isExcluded\n },\n log: (...args: string[]) => {\n const [namespace, format, ...rest] = args\n // Note: `console.warn` / `console.log` use `util.format` internally, so they can handle\n // `printf`-style string interpolation.\n const logWithFormatting = console.warn ?? console.log\n\n // console only formats first arg, concat ns+format\n logWithFormatting(`${namespace} ${format}`, ...rest)\n },\n formatters: {}, // not implemented\n}\n\n/**\n * Create a new debug instance with the given namespace.\n *\n * @example\n * ```ts\n * import Debug from '@prisma/debug'\n * const debug = Debug('prisma:client')\n * debug('Hello World')\n * ```\n */\nfunction debugCreate(namespace: string) {\n const instanceProps = {\n color: COLORS[lastColor++ % COLORS.length],\n enabled: topProps.enabled(namespace),\n namespace: namespace,\n log: topProps.log,\n extend: () => {}, // not implemented\n }\n\n const debugCall = (...args: any[]) => {\n const { enabled, namespace, color, log } = instanceProps\n\n // we push the args to our history of args\n if (args.length !== 0) {\n argsHistory.push([namespace, ...args])\n }\n\n // if it is too big, then we remove some\n if (argsHistory.length > MAX_ARGS_HISTORY) {\n argsHistory.shift()\n }\n\n if (topProps.enabled(namespace) || enabled) {\n const stringArgs = args.map((arg) => {\n if (typeof arg === 'string') {\n return arg\n }\n\n return safeStringify(arg)\n })\n\n const ms = `+${Date.now() - lastTimestamp}ms`\n lastTimestamp = Date.now()\n\n if (globalThis.DEBUG_COLORS) {\n log(kleur[color](bold(namespace)), ...stringArgs, kleur[color](ms))\n } else {\n log(namespace, ...stringArgs, ms)\n }\n }\n }\n\n return new Proxy(debugCall, {\n get: (_, prop) => instanceProps[prop],\n set: (_, prop, value) => (instanceProps[prop] = value),\n }) as typeof debugCall & typeof instanceProps\n}\n\nconst Debug = new Proxy(debugCreate, {\n get: (_, prop) => topProps[prop],\n set: (_, prop, value) => (topProps[prop] = value),\n}) as typeof debugCreate & typeof topProps\n\nfunction safeStringify(value: any, indent = 2) {\n const cache = new Set<any>()\n\n return JSON.stringify(\n value,\n (key, value) => {\n if (typeof value === 'object' && value !== null) {\n if (cache.has(value)) {\n return `[Circular *]`\n }\n\n cache.add(value)\n } else if (typeof value === 'bigint') {\n return value.toString()\n }\n\n return value\n },\n indent,\n )\n}\n\n/**\n * We can get the logs for all the last {@link MAX_ARGS_HISTORY} ${@link debugCall} that\n * have happened in the different packages. Useful to generate error report links.\n * @see https://stackoverflow.com/questions/417142/what-is-the-maximum-length-of-a-url-in-different-browsers\n * @param numChars\n * @returns\n */\nexport function getLogs(numChars = 7500): string {\n const logs = argsHistory\n .map(([namespace, ...args]) => {\n return `${namespace} ${args\n .map((arg) => {\n if (typeof arg === 'string') {\n return arg\n } else {\n return JSON.stringify(arg)\n }\n })\n .join(' ')}`\n })\n .join('\\n')\n\n if (logs.length < numChars) {\n return logs\n }\n\n return logs.slice(-numChars)\n}\n\nexport function clearLogs() {\n argsHistory.length = 0\n}\n\nexport { Debug }\nexport default Debug\n", "import minIndent from 'min-indent';\n\nexport default function stripIndent(string) {\n\tconst indent = minIndent(string);\n\n\tif (indent === 0) {\n\t\treturn string;\n\t}\n\n\tconst regex = new RegExp(`^[ \\\\t]{${indent}}`, 'gm');\n\n\treturn string.replace(regex, '');\n}\n", "export const PRISMA_POSTGRES_PROVIDER = 'prisma+postgres'\n\nexport const PRISMA_POSTGRES_PROTOCOL = `${PRISMA_POSTGRES_PROVIDER}:`\n\ndeclare const prismaPostgresBrand: unique symbol\ndeclare const prismaPostgresDevBrand: unique symbol\n\nexport type PrismaPostgresUrl<T extends string | URL> = T & {\n readonly [prismaPostgresBrand]: true\n}\n\nexport type PrismaPostgresDevUrl<T extends string | URL> = PrismaPostgresUrl<T> & {\n readonly [prismaPostgresDevBrand]: true\n}\n\nexport function isPrismaPostgres<T extends string | URL>(\n connectionString?: T,\n): connectionString is PrismaPostgresUrl<T> {\n return connectionString?.toString().startsWith(`${PRISMA_POSTGRES_PROTOCOL}//`) ?? false\n}\n\nexport function isPrismaPostgresDev<T extends string | URL>(\n connectionString?: T,\n): connectionString is PrismaPostgresDevUrl<T> {\n if (!isPrismaPostgres(connectionString)) {\n return false\n }\n\n const { host } = new URL(connectionString)\n\n return host.includes('localhost') || host.includes('127.0.0.1') || host.includes('[::1]')\n}\n", "import { blue, cyan, red, yellow } from 'kleur/colors'\n\nexport const tags = {\n error: red('prisma:error'),\n warn: yellow('prisma:warn'),\n info: cyan('prisma:info'),\n query: blue('prisma:query'),\n}\nexport const should = {\n warn: () => !process.env.PRISMA_DISABLE_WARNINGS,\n}\nexport function log(...data: any[]) {\n console.log(...data)\n}\nexport function warn(message: any, ...optionalParams: any[]) {\n if (should.warn()) {\n console.warn(`${tags.warn} ${message}`, ...optionalParams)\n }\n}\nexport function info(message: any, ...optionalParams: any[]) {\n console.info(`${tags.info} ${message}`, ...optionalParams)\n}\nexport function error(message: any, ...optionalParams: any[]) {\n console.error(`${tags.error} ${message}`, ...optionalParams)\n}\nexport function query(message: any, ...optionalParams: any[]) {\n console.log(`${tags.query} ${message}`, ...optionalParams)\n}\n", "/**\n * Utility function to ensure exhaustive checks for union types.\n *\n * @example\n * ```ts\n * declare const fruit: 'Apple' | 'Orange'\n *\n * switch (fruit) {\n * case 'Apple:\n * // do apple things\n * break;\n * case 'Orange:\n * // do orange things\n * break;\n * default:\n * // in case `fruit` type will expand in the future,\n * // we'll get a compile-time error here, listing all unhandled\n * // cases\n * assertNever(fruit, 'Unknown fruit')\n * }\n * ```\n * @param arg variable of the any union type. By the time `assertNever` is called\n * all possible cases of this union must already be handled\n * @param errorMessage error message to throw in runtime. Normally, should never happen\n * unless compile-time check is skipped\n */\nexport function assertNever(arg: never, errorMessage: string): never {\n throw new Error(errorMessage)\n}\n", "export default function ansiRegex({onlyFirst = false} = {}) {\n\t// Valid string terminator sequences are BEL, ESC\\, and 0x9c\n\tconst ST = '(?:\\\\u0007|\\\\u001B\\\\u005C|\\\\u009C)';\n\tconst pattern = [\n\t\t`[\\\\u001B\\\\u009B][[\\\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\\\d\\\\/#&.:=?%@~_]+)*|[a-zA-Z\\\\d]+(?:;[-a-zA-Z\\\\d\\\\/#&.:=?%@~_]*)*)?${ST})`,\n\t\t'(?:(?:\\\\d{1,4}(?:;\\\\d{0,4})*)?[\\\\dA-PR-TZcf-nq-uy=><~]))',\n\t].join('|');\n\n\treturn new RegExp(pattern, onlyFirst ? undefined : 'g');\n}\n", "import ansiRegex from 'ansi-regex';\n\nconst regex = ansiRegex();\n\nexport default function stripAnsi(string) {\n\tif (typeof string !== 'string') {\n\t\tthrow new TypeError(`Expected a \\`string\\`, got \\`${typeof string}\\``);\n\t}\n\n\t// Even though the regex is global, we don't need to reset the `.lastIndex`\n\t// because unlike `.exec()` and `.test()`, `.replace()` does it automatically\n\t// and doing it manually has a performance penalty.\n\treturn string.replace(regex, '');\n}\n", "import path from 'path'\n\n/**\n * Normalize `filePath` to use forward slashes as a separator. `filePath` is\n * treated as a path specific to the current platform, so backslashes will only\n * be replaced with forward slashes on Windows. On other platforms, where a\n * backslash is a valid filename character, it will be treated as such and will\n * not be replaced.\n */\nexport function pathToPosix(filePath: string): string {\n if (path.sep === path.posix.sep) {\n return filePath\n }\n return filePath.split(path.sep).join(path.posix.sep)\n}\n\n/**\n * Returns the longest common path ancestor of the two paths (which may also be equal to one or both of them).\n * If they don't share a common ancestor (which may be the case on Windows if both paths are on different disks),\n * returns `undefined`.\n */\nexport function longestCommonPathPrefix(pathA: string, pathB: string): string | undefined {\n if (!path.isAbsolute(pathA) || !path.isAbsolute(pathB)) {\n throw new Error('longestCommonPathPrefix expects absolute paths')\n }\n\n if (process.platform === 'win32' && (pathA.startsWith('\\\\\\\\') || pathB.startsWith('\\\\\\\\'))) {\n // Make both paths namespaced if at least one of them is.\n pathA = path.toNamespacedPath(pathA)\n pathB = path.toNamespacedPath(pathB)\n }\n\n const commonPrefix = longestCommonPrefix(pathA.split(path.sep), pathB.split(path.sep)).join(path.sep)\n\n if (commonPrefix === '') {\n return process.platform === 'win32' ? undefined : '/'\n }\n\n if (process.platform === 'win32' && ['\\\\', '\\\\\\\\?', '\\\\\\\\.'].includes(commonPrefix)) {\n return undefined\n }\n\n if (process.platform === 'win32' && commonPrefix.endsWith(':')) {\n // Disk specifier without a backslash at the end is not an absolute path on windows,\n // it refers to current working directory on that disk.\n return commonPrefix + '\\\\'\n }\n\n return commonPrefix\n}\n\nfunction longestCommonPrefix<T>(sequenceA: T[], sequenceB: T[]): T[] {\n const maxLen = Math.min(sequenceA.length, sequenceB.length)\n let sliceLen = 0\n\n while (sliceLen <= maxLen && sequenceA[sliceLen] === sequenceB[sliceLen]) {\n sliceLen++\n }\n\n return sequenceA.slice(0, sliceLen)\n}\n", "export function hasOwnProperty(object: object, key: PropertyKey): boolean {\n return Object.prototype.hasOwnProperty.call(object, key)\n}\n", "export function mapObjectValues<K extends PropertyKey, T, U>(\n object: Record<K, T>,\n mapper: (value: T, key: K) => U,\n): Record<K, U> {\n const result = {} as Record<K, U>\n\n for (const key of Object.keys(object)) {\n result[key] = mapper(object[key] as T, key as K)\n }\n\n return result\n}\n", "/**\n * Accepts an array and comparator function (similar to Array.prototype.sort)\n * and returns max element of that array, ordered with that comparator.\n * Functionally, equivalent of items.sort(comparator).at(-1), but performed non-destructively\n * in O(n)\n * @param items\n * @param comparator callback specifying the relative order of two items. See `Array.prototype.sort`\n * @returns\n */\nexport function maxWithComparator<T>(items: T[], comparator: (a: T, b: T) => number): T | undefined {\n if (items.length === 0) {\n return undefined\n }\n let result = items[0]\n\n for (let i = 1; i < items.length; i++) {\n const compareValue = comparator(result, items[i])\n // comparator returning negative number means that b>a\n if (compareValue < 0) {\n result = items[i]\n }\n }\n return result\n}\n\nexport function maxBy<T>(items: T[], callback: (item: T) => number): T | undefined {\n return maxWithComparator(items, (a, b) => callback(a) - callback(b))\n}\n", "/**\n * Used for preserving class names for minified class instances\n * Useful for error objects and other classes where public name\n * actually matters\n *\n * @param classObject\n * @param name\n */\nexport function setClassName(classObject: Function, name: string) {\n Object.defineProperty(classObject, 'name', {\n value: name,\n configurable: true,\n })\n}\n", "import { warn } from './logger'\n\nconst alreadyWarned = new Set()\n\nexport const warnOnce = (key: string, message: string, ...args: unknown[]) => {\n if (!alreadyWarned.has(key)) {\n alreadyWarned.add(key)\n warn(message, ...args)\n }\n}\n", "export function isDate(value: unknown): value is Date {\n return (\n value instanceof Date ||\n // date created in other JS context (for example, worker)\n Object.prototype.toString.call(value) === '[object Date]'\n )\n}\n\nexport function isValidDate(date: Date) {\n return date.toString() !== 'Invalid Date'\n}\n", "import { Decimal } from '@prisma/client-runtime-utils'\n\nimport { DecimalJsLike } from '../core/types/exported/DecimalJsLike'\n\nexport function isDecimalJsLike(value: unknown): value is DecimalJsLike {\n if (Decimal.isDecimal(value)) {\n return true\n }\n return (\n value !== null &&\n typeof value === 'object' &&\n typeof value['s'] === 'number' &&\n typeof value['e'] === 'number' &&\n typeof value['toFixed'] === 'function' &&\n Array.isArray(value['d'])\n )\n}\n", "import { PrismaClientValidationError } from '@prisma/client-runtime-utils'\n\nimport { ErrorFormat } from '../../getPrismaClient'\nimport { CallSite } from '../../utils/CallSite'\nimport { createErrorMessageWithContext } from '../../utils/createErrorMessageWithContext'\nimport { GlobalOmitOptions } from '../jsonProtocol/serializeJsonQuery'\nimport { JsArgs } from '../types/exported/JsApi'\nimport { ValidationError } from '../types/ValidationError'\nimport { applyValidationError } from './applyValidationError'\nimport { buildArgumentsRenderingTree, renderArgsTree } from './ArgumentsRenderingTree'\n\ntype ExceptionParams = {\n errors: ValidationError[]\n args: JsArgs\n callsite?: CallSite\n originalMethod: string\n errorFormat: ErrorFormat\n clientVersion: string\n globalOmit?: GlobalOmitOptions\n}\n\nexport function throwValidationException({\n args,\n errors,\n errorFormat,\n callsite,\n originalMethod,\n clientVersion,\n globalOmit,\n}: ExceptionParams): never {\n const argsTree = buildArgumentsRenderingTree(args)\n for (const error of errors) {\n applyValidationError(error, argsTree, globalOmit)\n }\n\n const { message, args: renderedArgs } = renderArgsTree(argsTree, errorFormat)\n\n const messageWithContext = createErrorMessageWithContext({\n message,\n callsite,\n originalMethod,\n showColors: errorFormat === 'pretty',\n callArguments: renderedArgs,\n })\n\n throw new PrismaClientValidationError(messageWithContext, { clientVersion })\n}\n", "export * from './convert'\nexport * from './dmmf'\nexport * from './util'\n", "import { DatamodelEnum, SchemaEnum } from './dmmf'\n\nexport function datamodelEnumToSchemaEnum(datamodelEnum: DatamodelEnum): SchemaEnum {\n return {\n name: datamodelEnum.name,\n values: datamodelEnum.values.map((v) => v.name),\n }\n}\n", "import { ReadonlyDeep } from './util'\n\nexport type Document = ReadonlyDeep<{\n datamodel: Datamodel\n schema: Schema\n mappings: Mappings\n}>\n\nexport type Mappings = ReadonlyDeep<{\n modelOperations: ModelMapping[]\n otherOperations: {\n read: string[]\n write: string[]\n }\n}>\n\nexport type OtherOperationMappings = ReadonlyDeep<{\n read: string[]\n write: string[]\n}>\n\nexport type DatamodelEnum = ReadonlyDeep<{\n name: string\n values: EnumValue[]\n dbName?: string | null\n documentation?: string\n}>\n\nexport type SchemaEnum = ReadonlyDeep<{\n name: string\n values: string[]\n}>\n\nexport type EnumValue = ReadonlyDeep<{\n name: string\n dbName: string | null\n}>\n\nexport type Datamodel = ReadonlyDeep<{\n models: Model[]\n enums: DatamodelEnum[]\n types: Model[]\n indexes: Index[]\n}>\n\nexport type uniqueIndex = ReadonlyDeep<{\n name: string\n fields: string[]\n}>\nexport type PrimaryKey = ReadonlyDeep<{\n name: string | null\n fields: string[]\n}>\nexport type Model = ReadonlyDeep<{\n name: string\n dbName: string | null\n schema: string | null\n fields: Field[]\n uniqueFields: string[][]\n uniqueIndexes: uniqueIndex[]\n documentation?: string\n primaryKey: PrimaryKey | null\n isGenerated?: boolean\n}>\n\nexport type FieldKind = 'scalar' | 'object' | 'enum' | 'unsupported'\n\nexport type FieldNamespace = 'model' | 'prisma'\nexport type FieldLocation = 'scalar' | 'inputObjectTypes' | 'outputObjectTypes' | 'enumTypes' | 'fieldRefTypes'\n\nexport type Field = ReadonlyDeep<{\n kind: FieldKind\n name: string\n isRequired: boolean\n isList: boolean\n isUnique: boolean\n isId: boolean\n isReadOnly: boolean\n isGenerated?: boolean // does not exist on 'type' but does on 'model'\n isUpdatedAt?: boolean // does not exist on 'type' but does on 'model'\n /**\n * Describes the data type in the same the way it is defined in the Prisma schema:\n * BigInt, Boolean, Bytes, DateTime, Decimal, Float, Int, JSON, String, $ModelName\n */\n type: string\n /**\n * Native database type, if specified.\n * For example, `@db.VarChar(191)` is encoded as `['VarChar', ['191']]`,\n * `@db.Text` is encoded as `['Text', []]`.\n */\n nativeType?: [string, string[]] | null\n dbName?: string | null\n hasDefaultValue: boolean\n default?: FieldDefault | FieldDefaultScalar | FieldDefaultScalar[]\n relationFromFields?: string[]\n relationToFields?: string[]\n relationOnDelete?: string\n relationOnUpdate?: string\n relationName?: string\n documentation?: string\n}>\n\nexport type FieldDefault = ReadonlyDeep<{\n name: string\n args: Array<string | number>\n}>\n\nexport type FieldDefaultScalar = string | boolean | number\n\nexport type Index = ReadonlyDeep<{\n model: string\n type: IndexType\n isDefinedOnField: boolean\n name?: string\n dbName?: string\n algorithm?: string\n clustered?: boolean\n fields: IndexField[]\n}>\n\nexport type IndexType = 'id' | 'normal' | 'unique' | 'fulltext'\n\nexport type IndexField = ReadonlyDeep<{\n name: string\n sortOrder?: SortOrder\n length?: number\n operatorClass?: string\n}>\n\nexport type SortOrder = 'asc' | 'desc'\n\nexport type Schema = ReadonlyDeep<{\n rootQueryType?: string\n rootMutationType?: string\n inputObjectTypes: {\n // For now there are no `model` InputTypes\n model?: InputType[]\n prisma?: InputType[]\n }\n outputObjectTypes: {\n model: OutputType[]\n prisma: OutputType[]\n }\n enumTypes: {\n model?: SchemaEnum[]\n prisma: SchemaEnum[]\n }\n fieldRefTypes: {\n prisma?: FieldRefType[]\n }\n}>\n\nexport type Query = ReadonlyDeep<{\n name: string\n args: SchemaArg[]\n output: QueryOutput\n}>\n\nexport type QueryOutput = ReadonlyDeep<{\n name: string\n isRequired: boolean\n isList: boolean\n}>\n\nexport type TypeRef<AllowedLocations extends FieldLocation> = {\n isList: boolean\n type: string\n location: AllowedLocations\n namespace?: FieldNamespace\n}\n\nexport type InputTypeRef = TypeRef<'scalar' | 'inputObjectTypes' | 'enumTypes' | 'fieldRefTypes'>\n\nexport type SchemaArg = ReadonlyDeep<{\n name: string\n comment?: string\n isNullable: boolean\n isRequired: boolean\n inputTypes: InputTypeRef[]\n isParameterizable: boolean\n requiresOtherFields?: string[]\n deprecation?: Deprecation\n}>\n\nexport type OutputType = ReadonlyDeep<{\n name: string\n fields: SchemaField[]\n}>\n\nexport type SchemaField = ReadonlyDeep<{\n name: string\n isNullable?: boolean\n outputType: OutputTypeRef\n args: SchemaArg[]\n deprecation?: Deprecation\n documentation?: string\n}>\n\nexport type OutputTypeRef = TypeRef<'scalar' | 'outputObjectTypes' | 'enumTypes'>\n\nexport type Deprecation = ReadonlyDeep<{\n sinceVersion: string\n reason: string\n plannedRemovalVersion?: string\n}>\n\nexport type InputType = ReadonlyDeep<{\n name: string\n constraints: {\n maxNumFields: number | null\n minNumFields: number | null\n fields?: string[]\n }\n meta?: {\n source?: string\n grouping?: string\n }\n fields: SchemaArg[]\n}>\n\nexport type FieldRefType = ReadonlyDeep<{\n name: string\n allowTypes: FieldRefAllowType[]\n fields: SchemaArg[]\n}>\n\nexport type FieldRefAllowType = TypeRef<'scalar' | 'enumTypes'>\n\nexport type ModelMapping = ReadonlyDeep<{\n model: string\n plural: string\n findUnique?: string | null\n findUniqueOrThrow?: string | null\n findFirst?: string | null\n findFirstOrThrow?: string | null\n findMany?: string | null\n create?: string | null\n createMany?: string | null\n createManyAndReturn?: string | null\n update?: string | null\n updateMany?: string | null\n updateManyAndReturn?: string | null\n upsert?: string | null\n delete?: string | null\n deleteMany?: string | null\n aggregate?: string | null\n groupBy?: string | null\n count?: string | null\n findRaw?: string | null\n aggregateRaw?: string | null\n}>\n\nexport enum ModelAction {\n findUnique = 'findUnique',\n findUniqueOrThrow = 'findUniqueOrThrow',\n findFirst = 'findFirst',\n findFirstOrThrow = 'findFirstOrThrow',\n findMany = 'findMany',\n create = 'create',\n createMany = 'createMany',\n createManyAndReturn = 'createManyAndReturn',\n update = 'update',\n updateMany = 'updateMany',\n updateManyAndReturn = 'updateManyAndReturn',\n upsert = 'upsert',\n delete = 'delete',\n deleteMany = 'deleteMany',\n groupBy = 'groupBy',\n count = 'count', // TODO: count does not actually exist in DMMF\n aggregate = 'aggregate',\n findRaw = 'findRaw',\n aggregateRaw = 'aggregateRaw',\n}\n", "import * as DMMF from '@prisma/dmmf'\nimport indentString from 'indent-string'\nimport { bold, dim, gray, red, underline } from 'kleur/colors'\n\nimport { CallSite, LocationInFile } from './CallSite'\nimport { SourceFileSlice } from './SourceFileSlice'\n\ndeclare global {\n /**\n * a global variable that is injected by us via jest to make our snapshots\n * work in clients that cannot read from disk (e.g. wasm or edge clients)\n */\n let $getTemplateParameters: typeof getTemplateParameters | undefined\n}\n\nexport interface ErrorArgs {\n callsite?: CallSite\n originalMethod: string\n message: string\n isPanic?: boolean\n showColors?: boolean\n callArguments?: string\n}\n\ntype Colors = {\n red: (str: string) => string\n gray: (str: string) => string\n dim: (str: string) => string\n bold: (str: string) => string\n underline: (str: string) => string\n highlightSource: (source: SourceFileSlice) => SourceFileSlice\n}\n\nconst colorsEnabled: Colors = {\n red,\n gray,\n dim,\n bold,\n underline,\n highlightSource: (source) => source.highlight(),\n}\n\nconst colorsDisabled: Colors = {\n red: (str) => str,\n gray: (str) => str,\n dim: (str) => str,\n bold: (str) => str,\n underline: (str) => str,\n highlightSource: (source) => source,\n}\n\ntype ErrorContextTemplateParameters = {\n functionName: string\n message: string\n location?: LocationInFile\n contextLines?: SourceFileSlice\n callArguments?: string\n isPanic: boolean\n}\n\nfunction getRawTemplateParameters({\n message,\n originalMethod,\n isPanic,\n callArguments,\n}: ErrorArgs): ErrorContextTemplateParameters {\n return {\n functionName: `prisma.${originalMethod}()`,\n message,\n isPanic: isPanic ?? false,\n callArguments,\n }\n}\n\nexport function getTemplateParameters(\n { callsite, message, originalMethod, isPanic, callArguments }: ErrorArgs,\n colors: Colors,\n): ErrorContextTemplateParameters {\n const templateParameters = getRawTemplateParameters({ message, originalMethod, isPanic, callArguments })\n\n // @ts-ignore\n if (!callsite || typeof window !== 'undefined') {\n return templateParameters\n }\n\n if (process.env.NODE_ENV === 'production') {\n return templateParameters\n }\n\n const callLocation = callsite.getLocation()\n if (!callLocation || !callLocation.lineNumber || !callLocation.columnNumber) {\n return templateParameters\n }\n\n const contextFirstLine = Math.max(1, callLocation.lineNumber - 3)\n let source = SourceFileSlice.read(callLocation.fileName)?.slice(contextFirstLine, callLocation.lineNumber)\n const invocationLine = source?.lineAt(callLocation.lineNumber)\n if (source && invocationLine) {\n const invocationLineIndent = getIndent(invocationLine)\n const invocationCallCode = findPrismaActionCall(invocationLine)\n if (!invocationCallCode) {\n return templateParameters\n }\n templateParameters.functionName = `${invocationCallCode.code})`\n templateParameters.location = callLocation\n\n if (!isPanic) {\n source = source.mapLineAt(callLocation.lineNumber, (line) => line.slice(0, invocationCallCode.openingBraceIndex))\n }\n\n source = colors.highlightSource(source)\n const numberColumnWidth = String(source.lastLineNumber).length\n templateParameters.contextLines = source\n .mapLines((line, lineNumber) => colors.gray(String(lineNumber).padStart(numberColumnWidth)) + ' ' + line)\n .mapLines((line) => colors.dim(line))\n .prependSymbolAt(callLocation.lineNumber, colors.bold(colors.red('\u2192')))\n\n if (callArguments) {\n let indentValue = invocationLineIndent + numberColumnWidth + 1 /* space between number and code */\n indentValue += 2 // arrow + space between arrow and number\n\n // indent all lines but first, because first line of the arguments will be printed\n // on the same line as the function call\n templateParameters.callArguments = indentString(callArguments, indentValue).slice(indentValue)\n }\n }\n return templateParameters\n}\n\nfunction findPrismaActionCall(str: string): { code: string; openingBraceIndex: number } | null {\n const allActions = Object.keys(DMMF.ModelAction).join('|')\n const regexp = new RegExp(String.raw`\\.(${allActions})\\(`)\n const match = regexp.exec(str)\n if (match) {\n const openingBraceIndex = match.index + match[0].length\n // to get the code we are slicing the string up to a found brace. We start\n // with first non-space character if space is found in the line before that or\n // 0 if it is not.\n const statementStart = str.lastIndexOf(' ', match.index) + 1\n return {\n code: str.slice(statementStart, openingBraceIndex),\n openingBraceIndex,\n }\n }\n return null\n}\n\nfunction getIndent(line: string): number {\n let spaceCount = 0\n for (let i = 0; i < line.length; i++) {\n if (line.charAt(i) !== ' ') {\n return spaceCount\n }\n spaceCount++\n }\n\n return spaceCount\n}\n\nfunction stringifyErrorMessage(\n { functionName, location, message, isPanic, contextLines, callArguments }: ErrorContextTemplateParameters,\n colors: Colors,\n) {\n const lines: string[] = ['']\n\n const introSuffix = location ? ' in' : ':'\n if (isPanic) {\n lines.push(colors.red(`Oops, an unknown error occurred! This is ${colors.bold('on us')}, you did nothing wrong.`))\n lines.push(colors.red(`It occurred in the ${colors.bold(`\\`${functionName}\\``)} invocation${introSuffix}`))\n } else {\n lines.push(colors.red(`Invalid ${colors.bold(`\\`${functionName}\\``)} invocation${introSuffix}`))\n }\n\n if (location) {\n lines.push(colors.underline(stringifyLocationInFile(location)))\n }\n\n if (contextLines) {\n lines.push('')\n\n const contextLineParts = [contextLines.toString()]\n\n if (callArguments) {\n contextLineParts.push(callArguments)\n contextLineParts.push(colors.dim(')'))\n }\n lines.push(contextLineParts.join(''))\n if (callArguments) {\n lines.push('')\n }\n } else {\n lines.push('')\n if (callArguments) {\n lines.push(callArguments)\n }\n lines.push('')\n }\n\n lines.push(message)\n return lines.join('\\n')\n}\n\nfunction stringifyLocationInFile(location: LocationInFile): string {\n const parts = [location.fileName]\n if (location.lineNumber) {\n parts.push(String(location.lineNumber))\n }\n\n if (location.columnNumber) {\n parts.push(String(location.columnNumber))\n }\n\n return parts.join(':')\n}\n\nexport function createErrorMessageWithContext(args: ErrorArgs): string {\n const colors = args.showColors ? colorsEnabled : colorsDisabled\n let templateParameters: ErrorContextTemplateParameters\n\n if (TARGET_BUILD_TYPE === 'wasm-compiler-edge') {\n if (typeof $getTemplateParameters !== 'undefined') {\n templateParameters = $getTemplateParameters(args, colors)\n } else {\n templateParameters = getRawTemplateParameters(args)\n }\n } else {\n templateParameters = getTemplateParameters(args, colors)\n }\n\n return stringifyErrorMessage(templateParameters, colors)\n}\n", "import fs from 'fs'\n\nimport { highlightTS } from '../highlight/highlight'\nimport { dedent } from './dedent'\n\n/**\n * Class represents a source code or it's slice.\n * Provides various methods for manipulating individual lines\n * of the files using original files line numbers, even if the file was\n * sliced\n */\nexport class SourceFileSlice {\n /**\n * First line, stored in the slice\n */\n readonly firstLineNumber: number\n private lines: string[]\n\n static read(filePath: string): SourceFileSlice | null {\n let content: string\n try {\n content = fs.readFileSync(filePath, 'utf-8')\n } catch (e) {\n return null\n }\n\n return SourceFileSlice.fromContent(content)\n }\n\n static fromContent(content: string): SourceFileSlice {\n const lines = content.split(/\\r?\\n/)\n\n return new SourceFileSlice(1, lines)\n }\n\n private constructor(firstLine: number, lines: string[]) {\n this.firstLineNumber = firstLine\n this.lines = lines\n }\n\n /**\n * First line, stored in the slice\n */\n get lastLineNumber(): number {\n return this.firstLineNumber + this.lines.length - 1\n }\n\n /**\n * Returns new `SourceFileLines` object, where specified\n * `lineNumber` is transformed, using provided `mapFn`\n * @param lineNumber\n * @param mapFn\n * @returns\n */\n mapLineAt(lineNumber: number, mapFn: (line: string) => string): SourceFileSlice {\n if (lineNumber < this.firstLineNumber || lineNumber > this.lines.length + this.firstLineNumber) {\n return this\n }\n const idx = lineNumber - this.firstLineNumber\n const newLines = [...this.lines]\n newLines[idx] = mapFn(newLines[idx])\n return new SourceFileSlice(this.firstLineNumber, newLines)\n }\n\n /**\n * Returns new `SourceFileLines` object, where each line is transformed\n * with provided `mapFn` callback. Callback receives content of the line and\n * original line number\n * @param mapFn\n * @returns\n */\n mapLines(mapFn: (line: string, lineNumber: number) => string): SourceFileSlice {\n return new SourceFileSlice(\n this.firstLineNumber,\n this.lines.map((line, i) => mapFn(line, this.firstLineNumber + i)),\n )\n }\n\n /**\n * Returns contents of the specified line\n * @param lineNumber\n * @returns\n */\n lineAt(lineNumber: number): string | undefined {\n return this.lines[lineNumber - this.firstLineNumber]\n }\n\n /**\n * Prepends a character to the specified line and adds padding\n * to all the other lines so that they'll align\n * @param atLine\n * @param str\n * @returns\n */\n prependSymbolAt(atLine: number, str: string): SourceFileSlice {\n return this.mapLines((line, lineNumber) => {\n if (lineNumber === atLine) {\n return `${str} ${line}`\n }\n return ` ${line}`\n })\n }\n\n /**\n * Creates a new slice from a subset of specified lines of the new code\n * Lines of a slice can still be manipulated using their number in original file\n *\n * @example\n * ```ts\n * const slice = source.slice(80, 100)\n * slice.lineAt(80) === source.lineAt(80)\n * ```\n *\n * @param fromLine\n * @param toLine\n * @returns\n */\n slice(fromLine: number, toLine: number): SourceFileSlice {\n const slicedLines = this.lines.slice(fromLine - 1, toLine).join('\\n')\n return new SourceFileSlice(fromLine, dedent(slicedLines).split('\\n'))\n }\n\n /**\n * Returns new `SourceFileLines` object, where code inside of it have been\n * highlighted as typescript\n * @returns\n */\n highlight(): SourceFileSlice {\n const highlighted = highlightTS(this.toString())\n return new SourceFileSlice(this.firstLineNumber, highlighted.split('\\n'))\n }\n\n toString(): string {\n return this.lines.join('\\n')\n }\n}\n", "import { blue, bold, cyan, gray, green, yellow } from 'kleur/colors'\n\nimport type { Theme } from './types'\n\nexport const theme: Theme = {\n keyword: cyan,\n entity: cyan,\n value: (s) => bold(blue(s)),\n punctuation: blue,\n directive: cyan,\n function: cyan,\n variable: (s) => bold(blue(s)),\n string: (s) => bold(green(s)),\n boolean: yellow,\n number: cyan,\n comment: gray,\n}\n", "import { theme } from './theme'\n\nconst identity = (str: string) => str\n\n/* eslint-disable */\n\n/* **********************************************\n Begin prism-core.js\n********************************************** */\n\nconst _self: any = {}\n\n/**\n * Prism: Lightweight, robust, elegant syntax highlighting\n * MIT license http://www.opensource.org/licenses/mit-license.php/\n * @author Lea Verou http://lea.verou.me\n */\n\n// Private helper vars\nlet uniqueId = 0\n\nexport var Prism: any = {\n manual: _self.Prism && _self.Prism.manual,\n disableWorkerMessageHandler: _self.Prism && _self.Prism.disableWorkerMessageHandler,\n util: {\n encode: function (tokens: any) {\n if (tokens instanceof Token) {\n const anyTokens: any = tokens\n return new Token(anyTokens.type, Prism.util.encode(anyTokens.content), anyTokens.alias)\n } else if (Array.isArray(tokens)) {\n return tokens.map(Prism.util.encode)\n } else {\n return tokens\n .replace(/&/g, '&')\n .replace(/</g, '<')\n .replace(/\\u00a0/g, ' ')\n }\n },\n\n type: function (o) {\n return Object.prototype.toString.call(o).slice(8, -1)\n },\n\n objId: function (obj) {\n if (!obj['__id']) {\n Object.defineProperty(obj, '__id', { value: ++uniqueId })\n }\n return obj['__id']\n },\n\n // Deep clone a language definition (e.g. to extend it)\n clone: function deepClone(o, visited?: any) {\n let clone,\n id,\n type = Prism.util.type(o)\n visited = visited || {}\n\n switch (type) {\n case 'Object':\n id = Prism.util.objId(o)\n if (visited[id]) {\n return visited[id]\n }\n clone = {}\n visited[id] = clone\n\n for (const key in o) {\n if (o.hasOwnProperty(key)) {\n clone[key] = deepClone(o[key], visited)\n }\n }\n\n return clone\n\n case 'Array':\n id = Prism.util.objId(o)\n if (visited[id]) {\n return visited[id]\n }\n clone = []\n visited[id] = clone\n\n o.forEach(function (v, i) {\n clone[i] = deepClone(v, visited)\n })\n\n return clone\n\n default:\n return o\n }\n },\n },\n\n languages: {\n extend: function (id, redef) {\n const lang = Prism.util.clone(Prism.languages[id])\n\n for (const key in redef) {\n lang[key] = redef[key]\n }\n\n return lang\n },\n\n /**\n * Insert a token before another token in a language literal\n * As this needs to recreate the object (we cannot actually insert before keys in object literals),\n * we cannot just provide an object, we need an object and a key.\n * @param inside The key (or language id) of the parent\n * @param before The key to insert before.\n * @param insert Object with the key/value pairs to insert\n * @param root The object that contains `inside`. If equal to Prism.languages, it can be omitted.\n */\n insertBefore: function (inside, before, insert, root) {\n root = root || Prism.languages\n const grammar = root[inside]\n const ret = {}\n\n for (const token in grammar) {\n if (grammar.hasOwnProperty(token)) {\n if (token == before) {\n for (const newToken in insert) {\n if (insert.hasOwnProperty(newToken)) {\n ret[newToken] = insert[newToken]\n }\n }\n }\n\n // Do not insert token which also occur in insert. See #1525\n if (!insert.hasOwnProperty(token)) {\n ret[token] = grammar[token]\n }\n }\n }\n\n const old = root[inside]\n root[inside] = ret\n\n // Update references in other language definitions\n Prism.languages.DFS(Prism.languages, function (this: any, key, value) {\n if (value === old && key != inside) {\n this[key] = ret\n }\n })\n\n return ret\n },\n\n // Traverse a language definition with Depth First Search\n DFS: function DFS(o, callback, type?: any, visited?: any) {\n visited = visited || {}\n\n const objId = Prism.util.objId\n\n for (const i in o) {\n if (o.hasOwnProperty(i)) {\n callback.call(o, i, o[i], type || i)\n\n const property = o[i],\n propertyType = Prism.util.type(property)\n\n if (propertyType === 'Object' && !visited[objId(property)]) {\n visited[objId(property)] = true\n DFS(property, callback, null, visited)\n } else if (propertyType === 'Array' && !visited[objId(property)]) {\n visited[objId(property)] = true\n DFS(property, callback, i, visited)\n }\n }\n }\n },\n },\n plugins: {},\n\n highlight: function (text, grammar, language) {\n const env: any = {\n code: text,\n grammar: grammar,\n language: language,\n }\n Prism.hooks.run('before-tokenize', env)\n env.tokens = Prism.tokenize(env.code, env.grammar)\n Prism.hooks.run('after-tokenize', env)\n return Token.stringify(Prism.util.encode(env.tokens), env.language)\n },\n\n matchGrammar: function (text, strarr, grammar, index, startPos, oneshot, target?: any) {\n for (const token in grammar) {\n if (!grammar.hasOwnProperty(token) || !grammar[token]) {\n continue\n }\n\n if (token == target) {\n return\n }\n\n let patterns = grammar[token]\n patterns = Prism.util.type(patterns) === 'Array' ? patterns : [patterns]\n\n for (let j = 0; j < patterns.length; ++j) {\n let pattern = patterns[j],\n inside = pattern.inside,\n lookbehind = !!pattern.lookbehind,\n greedy = !!pattern.greedy,\n lookbehindLength = 0,\n alias = pattern.alias\n\n if (greedy && !pattern.pattern.global) {\n // Without the global flag, lastIndex won't work\n const flags = pattern.pattern.toString().match(/[imuy]*$/)[0]\n pattern.pattern = RegExp(pattern.pattern.source, flags + 'g')\n }\n\n pattern = pattern.pattern || pattern\n\n // Don\u2019t cache length as it changes during the loop\n for (let i = index, pos = startPos; i < strarr.length; pos += strarr[i].length, ++i) {\n let str = strarr[i]\n\n if (strarr.length > text.length) {\n // Something went terribly wrong, ABORT, ABORT!\n return\n }\n\n if (str instanceof Token) {\n continue\n }\n\n if (greedy && i != strarr.length - 1) {\n pattern.lastIndex = pos\n var match = pattern.exec(text)\n if (!match) {\n break\n }\n\n var from = match.index + (lookbehind ? match[1].length : 0),\n to = match.index + match[0].length,\n k = i,\n p = pos\n\n for (let len = strarr.length; k < len && (p < to || (!strarr[k].type && !strarr[k - 1].greedy)); ++k) {\n p += strarr[k].length\n // Move the index i to the element in strarr that is closest to from\n if (from >= p) {\n ++i\n pos = p\n }\n }\n\n // If strarr[i] is a Token, then the match starts inside another Token, which is invalid\n if (strarr[i] instanceof Token) {\n continue\n }\n\n // Number of tokens to delete and replace with the new match\n delNum = k - i\n str = text.slice(pos, p)\n match.index -= pos\n } else {\n pattern.lastIndex = 0\n\n var match = pattern.exec(str),\n delNum = 1\n }\n\n if (!match) {\n if (oneshot) {\n break\n }\n\n continue\n }\n\n if (lookbehind) {\n lookbehindLength = match[1] ? match[1].length : 0\n }\n\n var from = match.index + lookbehindLength,\n match = match[0].slice(lookbehindLength),\n to = from + match.length,\n before = str.slice(0, from),\n after = str.slice(to)\n\n const args: any = [i, delNum]\n\n if (before) {\n ++i\n pos += before.length\n args.push(before)\n }\n\n const wrapped = new Token(token, inside ? Prism.tokenize(match, inside) : match, alias, match, greedy)\n\n args.push(wrapped)\n\n if (after) {\n args.push(after)\n }\n\n Array.prototype.splice.apply(strarr, args)\n\n if (delNum != 1) Prism.matchGrammar(text, strarr, grammar, i, pos, true, token)\n\n if (oneshot) break\n }\n }\n }\n },\n\n tokenize: function (text, grammar) {\n const strarr = [text]\n\n const rest = grammar.rest\n\n if (rest) {\n for (const token in rest) {\n grammar[token] = rest[token]\n }\n\n delete grammar.rest\n }\n\n Prism.matchGrammar(text, strarr, grammar, 0, 0, false)\n\n return strarr\n },\n\n hooks: {\n all: {},\n\n add: function (name, callback) {\n const hooks = Prism.hooks.all\n\n hooks[name] = hooks[name] || []\n\n hooks[name].push(callback)\n },\n\n run: function (name, env) {\n const callbacks = Prism.hooks.all[name]\n\n if (!callbacks || !callbacks.length) {\n return\n }\n\n for (var i = 0, callback; (callback = callbacks[i++]); ) {\n callback(env)\n }\n },\n },\n\n Token: Token,\n}\n\nPrism.languages.clike = {\n comment: [\n {\n pattern: /(^|[^\\\\])\\/\\*[\\s\\S]*?(?:\\*\\/|$)/,\n lookbehind: true,\n },\n {\n pattern: /(^|[^\\\\:])\\/\\/.*/,\n lookbehind: true,\n greedy: true,\n },\n ],\n string: {\n pattern: /([\"'])(?:\\\\(?:\\r\\n|[\\s\\S])|(?!\\1)[^\\\\\\r\\n])*\\1/,\n greedy: true,\n },\n 'class-name': {\n pattern: /((?:\\b(?:class|interface|extends|implements|trait|instanceof|new)\\s+)|(?:catch\\s+\\())[\\w.\\\\]+/i,\n lookbehind: true,\n inside: {\n punctuation: /[.\\\\]/,\n },\n },\n keyword: /\\b(?:if|else|while|do|for|return|in|instanceof|function|new|try|throw|catch|finally|null|break|continue)\\b/,\n boolean: /\\b(?:true|false)\\b/,\n function: /\\w+(?=\\()/,\n number: /\\b0x[\\da-f]+\\b|(?:\\b\\d+\\.?\\d*|\\B\\.\\d+)(?:e[+-]?\\d+)?/i,\n operator: /--?|\\+\\+?|!=?=?|<=?|>=?|==?=?|&&?|\\|\\|?|\\?|\\*|\\/|~|\\^|%/,\n punctuation: /[{}[\\];(),.:]/,\n}\n\nPrism.languages.javascript = Prism.languages.extend('clike', {\n 'class-name': [\n Prism.languages.clike['class-name'],\n {\n pattern: /(^|[^$\\w\\xA0-\\uFFFF])[_$A-Z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*(?=\\.(?:prototype|constructor))/,\n lookbehind: true,\n },\n ],\n keyword: [\n {\n pattern: /((?:^|})\\s*)(?:catch|finally)\\b/,\n lookbehind: true,\n },\n {\n pattern:\n /(^|[^.])\\b(?:as|async(?=\\s*(?:function\\b|\\(|[$\\w\\xA0-\\uFFFF]|$))|await|break|case|class|const|continue|debugger|default|delete|do|else|enum|export|extends|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)\\b/,\n lookbehind: true,\n },\n ],\n number:\n /\\b(?:(?:0[xX](?:[\\dA-Fa-f](?:_[\\dA-Fa-f])?)+|0[bB](?:[01](?:_[01])?)+|0[oO](?:[0-7](?:_[0-7])?)+)n?|(?:\\d(?:_\\d)?)+n|NaN|Infinity)\\b|(?:\\b(?:\\d(?:_\\d)?)+\\.?(?:\\d(?:_\\d)?)*|\\B\\.(?:\\d(?:_\\d)?)+)(?:[Ee][+-]?(?:\\d(?:_\\d)?)+)?/,\n // Allow for all non-ASCII characters (See http://stackoverflow.com/a/2008444)\n function: /[_$a-zA-Z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*(?=\\s*(?:\\.\\s*(?:apply|bind|call)\\s*)?\\()/,\n operator: /-[-=]?|\\+[+=]?|!=?=?|<<?=?|>>?>?=?|=(?:==?|>)?|&[&=]?|\\|[|=]?|\\*\\*?=?|\\/=?|~|\\^=?|%=?|\\?|\\.{3}/,\n})\n\nPrism.languages.javascript['class-name'][0].pattern =\n /(\\b(?:class|interface|extends|implements|instanceof|new)\\s+)[\\w.\\\\]+/\n\nPrism.languages.insertBefore('javascript', 'keyword', {\n regex: {\n pattern:\n /((?:^|[^$\\w\\xA0-\\uFFFF.\"'\\])\\s])\\s*)\\/(\\[(?:[^\\]\\\\\\r\\n]|\\\\.)*]|\\\\.|[^/\\\\\\[\\r\\n])+\\/[gimyus]{0,6}(?=\\s*($|[\\r\\n,.;})\\]]))/,\n lookbehind: true,\n greedy: true,\n },\n // This must be declared before keyword because we use \"function\" inside the look-forward\n 'function-variable': {\n pattern:\n /[_$a-zA-Z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*(?=\\s*[=:]\\s*(?:async\\s*)?(?:\\bfunction\\b|(?:\\((?:[^()]|\\([^()]*\\))*\\)|[_$a-zA-Z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*)\\s*=>))/,\n alias: 'function',\n },\n parameter: [\n {\n pattern: /(function(?:\\s+[_$A-Za-z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*)?\\s*\\(\\s*)(?!\\s)(?:[^()]|\\([^()]*\\))+?(?=\\s*\\))/,\n lookbehind: true,\n inside: Prism.languages.javascript,\n },\n {\n pattern: /[_$a-z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*(?=\\s*=>)/i,\n inside: Prism.languages.javascript,\n },\n {\n pattern: /(\\(\\s*)(?!\\s)(?:[^()]|\\([^()]*\\))+?(?=\\s*\\)\\s*=>)/,\n lookbehind: true,\n inside: Prism.languages.javascript,\n },\n {\n pattern:\n /((?:\\b|\\s|^)(?!(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)(?![$\\w\\xA0-\\uFFFF]))(?:[_$A-Za-z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*\\s*)\\(\\s*)(?!\\s)(?:[^()]|\\([^()]*\\))+?(?=\\s*\\)\\s*\\{)/,\n lookbehind: true,\n inside: Prism.languages.javascript,\n },\n ],\n constant: /\\b[A-Z](?:[A-Z_]|\\dx?)*\\b/,\n})\n\nif (Prism.languages.markup) {\n Prism.languages.markup.tag.addInlined('script', 'javascript')\n}\n\nPrism.languages.js = Prism.languages.javascript\n\nPrism.languages.typescript = Prism.languages.extend('javascript', {\n // From JavaScript Prism keyword list and TypeScript language spec: https://github.com/Microsoft/TypeScript/blob/master/doc/spec.md#221-reserved-words\n keyword:\n /\\b(?:abstract|as|async|await|break|case|catch|class|const|constructor|continue|debugger|declare|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|is|keyof|let|module|namespace|new|null|of|package|private|protected|public|readonly|return|require|set|static|super|switch|this|throw|try|type|typeof|var|void|while|with|yield)\\b/,\n builtin: /\\b(?:string|Function|any|number|boolean|Array|symbol|console|Promise|unknown|never)\\b/,\n})\n\nPrism.languages.ts = Prism.languages.typescript\n\nexport function Token(this: any, type, content, alias, matchedStr?: any, greedy?: any) {\n this.type = type\n this.content = content\n this.alias = alias\n // Copy of the full string this token was created from\n this.length = (matchedStr || '').length | 0\n this.greedy = !!greedy\n}\n\nToken.stringify = function (o, language?: any) {\n if (typeof o == 'string') {\n return o\n }\n\n if (Array.isArray(o)) {\n return o\n .map(function (element) {\n return Token.stringify(element, language)\n })\n .join('')\n }\n\n return getColorForSyntaxKind(o.type)(o.content)\n}\n\nfunction getColorForSyntaxKind(syntaxKind: string) {\n return theme[syntaxKind] || identity\n}\n", "import { Prism, Token } from './prism'\nimport type { SyntaxDefinition } from './types'\n\nexport function highlightTS(str: string) {\n return highlight(str, Prism.languages.javascript)\n}\n\nfunction highlight(str: string, grammar: SyntaxDefinition) {\n const tokens = Prism.tokenize(str, grammar)\n return tokens.map((t) => Token.stringify(t)).join('')\n}\n", "import strip from 'strip-indent'\n\nexport function dedent(str: string): string {\n return strip(str)\n}\n", "import { uncapitalize } from '@prisma/client-common'\nimport levenshtein from 'js-levenshtein'\n\nimport {\n ArgumentDescription,\n EmptySelectionError,\n InputTypeDescription,\n InvalidArgumentTypeError,\n InvalidArgumentValueError,\n OutputTypeDescription,\n RequiredArgumentMissingError,\n SomeFieldsMissingError,\n TooManyFieldsGivenError,\n UnknownArgumentError,\n UnknownInputFieldError,\n UnknownSelectionFieldError,\n ValueTooLargeError,\n} from '../engines'\nimport { GlobalOmitOptions } from '../jsonProtocol/serializeJsonQuery'\nimport {\n IncludeOnScalarError,\n InvalidSelectionValueError,\n MutuallyExclusiveFieldsError,\n ValidationError,\n} from '../types/ValidationError'\nimport { applyUnionError } from './applyUnionError'\nimport { ArgumentsRenderingTree } from './ArgumentsRenderingTree'\nimport { Colors } from './base'\nimport { ObjectField } from './ObjectField'\nimport { ObjectFieldSuggestion } from './ObjectFieldSuggestion'\nimport { ObjectValue } from './ObjectValue'\nimport { ScalarValue } from './ScalarValue'\nimport { SuggestionObjectValue } from './SuggestionObjectValue'\n\n/**\n * Given the validation error and arguments rendering tree, applies corresponding\n * formatting to an error tree and adds all relevant messages.\n *\n * @param error\n * @param args\n */\nexport function applyValidationError(\n error: ValidationError,\n args: ArgumentsRenderingTree,\n globalOmit?: GlobalOmitOptions,\n): void {\n switch (error.kind) {\n case 'MutuallyExclusiveFields':\n applyMutuallyExclusiveFieldsError(error, args)\n break\n case 'IncludeOnScalar':\n applyIncludeOnScalarError(error, args)\n break\n case 'EmptySelection':\n applyEmptySelectionError(error, args, globalOmit)\n break\n case 'UnknownSelectionField':\n applyUnknownSelectionFieldError(error, args)\n break\n case 'InvalidSelectionValue':\n applyInvalidSelectionValueError(error, args)\n break\n case 'UnknownArgument':\n applyUnknownArgumentError(error, args)\n break\n case 'UnknownInputField':\n applyUnknownInputFieldError(error, args)\n break\n case 'RequiredArgumentMissing':\n applyRequiredArgumentMissingError(error, args)\n break\n case 'InvalidArgumentType':\n applyInvalidArgumentTypeError(error, args)\n break\n case 'InvalidArgumentValue':\n applyInvalidArgumentValueError(error, args)\n break\n case 'ValueTooLarge':\n applyValueTooLargeError(error, args)\n break\n case 'SomeFieldsMissing':\n applySomeFieldsMissingError(error, args)\n break\n case 'TooManyFieldsGiven':\n applyTooManyFieldsGivenError(error, args)\n break\n case 'Union':\n applyUnionError(error, args, globalOmit)\n break\n default:\n throw new Error('not implemented: ' + error.kind)\n }\n}\n\nfunction applyMutuallyExclusiveFieldsError(error: MutuallyExclusiveFieldsError, argsTree: ArgumentsRenderingTree) {\n const object = argsTree.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n if (object) {\n object.getField(error.firstField)?.markAsError()\n object.getField(error.secondField)?.markAsError()\n }\n\n argsTree.addErrorMessage(\n (colors) =>\n `Please ${colors.bold('either')} use ${colors.green(`\\`${error.firstField}\\``)} or ${colors.green(\n `\\`${error.secondField}\\``,\n )}, but ${colors.red('not both')} at the same time.`,\n )\n}\n\nfunction applyIncludeOnScalarError(error: IncludeOnScalarError, argsTree: ArgumentsRenderingTree) {\n const [selectionPath, field] = splitPath(error.selectionPath)\n const outputType = error.outputType\n\n const object = argsTree.arguments.getDeepSelectionParent(selectionPath)?.value\n if (object) {\n object.getField(field)?.markAsError()\n\n if (outputType) {\n for (const field of outputType.fields) {\n if (field.isRelation) {\n object.addSuggestion(new ObjectFieldSuggestion(field.name, 'true'))\n }\n }\n }\n }\n\n argsTree.addErrorMessage((colors) => {\n let msg = `Invalid scalar field ${colors.red(`\\`${field}\\``)} for ${colors.bold('include')} statement`\n if (outputType) {\n msg += ` on model ${colors.bold(outputType.name)}. ${availableOptionsMessage(colors)}`\n } else {\n msg += '.'\n }\n\n msg += `\\nNote that ${colors.bold('include')} statements only accept relation fields.`\n return msg\n })\n}\n\nfunction applyEmptySelectionError(\n error: EmptySelectionError,\n argsTree: ArgumentsRenderingTree,\n globalOmit?: GlobalOmitOptions,\n) {\n const subSelection = argsTree.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n if (subSelection) {\n const omit = subSelection.getField('omit')?.value.asObject()\n if (omit) {\n applyEmptySelectionErrorOmit(error, argsTree, omit)\n return\n }\n if (subSelection.hasField('select')) {\n applyEmptySelectionErrorSelect(error, argsTree)\n return\n }\n }\n\n if (globalOmit?.[uncapitalize(error.outputType.name)]) {\n applyEmptySelectionErrorGlobalOmit(error, argsTree)\n return\n }\n\n // should never happen, but in case it does\n argsTree.addErrorMessage(() => `Unknown field at \"${error.selectionPath.join('.')} selection\"`)\n}\n\n// case for `EmptySelectionError`, triggered by excessive omit\nfunction applyEmptySelectionErrorOmit(\n error: EmptySelectionError,\n argsTree: ArgumentsRenderingTree,\n omitValue: ObjectValue,\n) {\n omitValue.removeAllFields()\n for (const field of error.outputType.fields) {\n omitValue.addSuggestion(new ObjectFieldSuggestion(field.name, 'false'))\n }\n\n argsTree.addErrorMessage((colors) => {\n return `The ${colors.red('omit')} statement includes every field of the model ${colors.bold(\n error.outputType.name,\n )}. At least one field must be included in the result`\n })\n}\n\n// case for `EmptySelectionError`, triggered by empty/falsy `select`\nfunction applyEmptySelectionErrorSelect(error: EmptySelectionError, argsTree: ArgumentsRenderingTree) {\n const outputType = error.outputType\n const selection = argsTree.arguments.getDeepSelectionParent(error.selectionPath)?.value\n const isEmpty = selection?.isEmpty() ?? false\n\n if (selection) {\n // If selection has fields and we get EmptySelection error, it means all fields within the\n // selection are false. We have 2 possible ways to handle suggestions here:\n //\n // 1. Suggest only the fields, not present inside of the selection. Example:\n //\n // {\n // select: {\n // id: false\n // posts: false,\n // ? name?: true\n // ? email?: true\n // }\n // }\n // There are couple of possible problems here. First, we are assuming that user needs to\n // add new field to the selection, rather than change one of the existing ones to true.\n // Second, we might end up in a situation where all fields are already used in selection and we have nothing left to suggest.\n //\n // 2.Completely ignore users input and suggest all the fields. Example rendering:\n // {\n // select: {\n // ? id?: true\n // ? posts?: true,\n // ? name?: true\n // ? email?: true\n // }\n // }\n //\n // So we will be suggesting to either change one of the fields to true, or add a new one which would be true.\n // This is the approach we are taking and in order to it, we need to remove all the fields from selection. Code\n // below will then add them back as a suggestion.\n selection.removeAllFields()\n addSelectionSuggestions(selection, outputType)\n }\n\n argsTree.addErrorMessage((colors) => {\n if (isEmpty) {\n return `The ${colors.red('`select`')} statement for type ${colors.bold(\n outputType.name,\n )} must not be empty. ${availableOptionsMessage(colors)}`\n }\n return `The ${colors.red('`select`')} statement for type ${colors.bold(outputType.name)} needs ${colors.bold(\n 'at least one truthy value',\n )}.`\n })\n}\n\n// case for `EmptySelectionError`, triggered by excessive global omit\nfunction applyEmptySelectionErrorGlobalOmit(error: EmptySelectionError, argsTree: ArgumentsRenderingTree) {\n const suggestedOmitConfig = new SuggestionObjectValue()\n for (const field of error.outputType.fields) {\n if (!field.isRelation) {\n suggestedOmitConfig.addField(field.name, 'false')\n }\n }\n\n const omitSuggestion = new ObjectFieldSuggestion('omit', suggestedOmitConfig).makeRequired()\n\n if (error.selectionPath.length === 0) {\n argsTree.arguments.addSuggestion(omitSuggestion)\n } else {\n const [parentPath, fieldName] = splitPath(error.selectionPath)\n const parent = argsTree.arguments.getDeepSelectionParent(parentPath)?.value.asObject()\n const field = parent?.getField(fieldName)\n if (field) {\n const fieldValue = field?.value.asObject() ?? new ObjectValue()\n fieldValue.addSuggestion(omitSuggestion)\n field.value = fieldValue\n }\n }\n\n // neither select, nor omit are used, but global omit global omit configuration for the model exists\n argsTree.addErrorMessage((colors) => {\n return `The global ${colors.red('omit')} configuration excludes every field of the model ${colors.bold(\n error.outputType.name,\n )}. At least one field must be included in the result`\n })\n}\n\nfunction applyUnknownSelectionFieldError(error: UnknownSelectionFieldError, argsTree: ArgumentsRenderingTree) {\n const locateResult = locateSelectionField(error.selectionPath, argsTree)\n if (locateResult.parentKind !== 'unknown') {\n locateResult.field.markAsError()\n const parent = locateResult.parent\n switch (locateResult.parentKind) {\n case 'select':\n addSelectionSuggestions(parent, error.outputType)\n break\n case 'include':\n addInclusionSuggestions(parent, error.outputType)\n break\n case 'omit':\n addOmissionSuggestions(parent, error.outputType)\n break\n }\n }\n argsTree.addErrorMessage((colors) => {\n const parts = [`Unknown field ${colors.red(`\\`${locateResult.fieldName}\\``)}`]\n if (locateResult.parentKind !== 'unknown') {\n parts.push(`for ${colors.bold(locateResult.parentKind)} statement`)\n }\n parts.push(`on model ${colors.bold(`\\`${error.outputType.name}\\``)}.`)\n parts.push(availableOptionsMessage(colors))\n return parts.join(' ')\n })\n}\n\nfunction applyInvalidSelectionValueError(error: InvalidSelectionValueError, argsTree: ArgumentsRenderingTree) {\n const locateResult = locateSelectionField(error.selectionPath, argsTree)\n if (locateResult.parentKind !== 'unknown') {\n locateResult.field.value.markAsError()\n }\n\n argsTree.addErrorMessage((colors) => {\n return `Invalid value for selection field \\`${colors.red(locateResult.fieldName)}\\`: ${error.underlyingError}`\n })\n}\n\nfunction applyUnknownArgumentError(error: UnknownArgumentError, argsTree: ArgumentsRenderingTree) {\n const argName = error.argumentPath[0]\n const selection = argsTree.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n\n if (selection) {\n selection.getField(argName)?.markAsError()\n addArgumentsSuggestions(selection, error.arguments)\n }\n\n argsTree.addErrorMessage((colors) =>\n unknownArgumentMessage(\n colors,\n argName,\n error.arguments.map((arg) => arg.name),\n ),\n )\n}\n\nfunction applyUnknownInputFieldError(error: UnknownInputFieldError, argsTree: ArgumentsRenderingTree) {\n const [argParentPath, argName] = splitPath(error.argumentPath)\n const selection = argsTree.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n\n if (selection) {\n selection.getDeepField(error.argumentPath)?.markAsError()\n const argParent = selection.getDeepFieldValue(argParentPath)?.asObject()\n if (argParent) {\n addInputSuggestions(argParent, error.inputType)\n }\n }\n\n argsTree.addErrorMessage((colors) =>\n unknownArgumentMessage(\n colors,\n argName,\n error.inputType.fields.map((f) => f.name),\n ),\n )\n}\n\nfunction unknownArgumentMessage(colors: Colors, argName: string, options: string[]) {\n const parts = [`Unknown argument \\`${colors.red(argName)}\\`.`]\n const suggestion = getSuggestion(argName, options)\n\n if (suggestion) {\n parts.push(`Did you mean \\`${colors.green(suggestion)}\\`?`)\n }\n\n if (options.length > 0) {\n parts.push(availableOptionsMessage(colors))\n }\n\n return parts.join(' ')\n}\n\nfunction applyRequiredArgumentMissingError(error: RequiredArgumentMissingError, args: ArgumentsRenderingTree) {\n let existingField: ObjectField | undefined = undefined\n\n args.addErrorMessage((colors) => {\n if (existingField?.value instanceof ScalarValue && existingField.value.text === 'null') {\n return `Argument \\`${colors.green(argumentName)}\\` must not be ${colors.red('null')}.`\n }\n return `Argument \\`${colors.green(argumentName)}\\` is missing.`\n })\n const selection = args.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n if (!selection) {\n return\n }\n\n const [argParent, argumentName] = splitPath(error.argumentPath)\n const objectSuggestion = new SuggestionObjectValue()\n const parent = selection.getDeepFieldValue(argParent)?.asObject()\n if (!parent) {\n return\n }\n\n existingField = parent.getField(argumentName)\n if (existingField) {\n parent.removeField(argumentName)\n }\n\n if (error.inputTypes.length === 1 && error.inputTypes[0].kind === 'object') {\n for (const field of error.inputTypes[0].fields) {\n objectSuggestion.addField(field.name, field.typeNames.join(' | '))\n }\n\n parent.addSuggestion(new ObjectFieldSuggestion(argumentName, objectSuggestion).makeRequired())\n } else {\n const typeName = error.inputTypes.map(getInputTypeName).join(' | ')\n parent.addSuggestion(new ObjectFieldSuggestion(argumentName, typeName).makeRequired())\n }\n\n if (error.dependentArgumentPath) {\n selection.getDeepField(error.dependentArgumentPath)?.markAsError()\n const [, dependentArgumentName] = splitPath(error.dependentArgumentPath)\n args.addErrorMessage((colors) => {\n return `Argument \\`${colors.green(argumentName)}\\` is required because argument \\`${colors.green(\n dependentArgumentName,\n )}\\` was provided.`\n })\n }\n}\n\nfunction getInputTypeName(description: InputTypeDescription) {\n if (description.kind === 'list') {\n return `${getInputTypeName(description.elementType)}[]`\n }\n return description.name\n}\n\nfunction applyInvalidArgumentTypeError(error: InvalidArgumentTypeError, args: ArgumentsRenderingTree) {\n const argName = error.argument.name\n const selection = args.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n if (selection) {\n selection.getDeepFieldValue(error.argumentPath)?.markAsError()\n }\n\n args.addErrorMessage((colors) => {\n const expected = joinWithPreposition(\n 'or',\n error.argument.typeNames.map((type) => colors.green(type)),\n )\n // TODO: print value\n return `Argument \\`${colors.bold(argName)}\\`: Invalid value provided. Expected ${expected}, provided ${colors.red(\n error.inferredType,\n )}.`\n })\n}\n\nfunction applyInvalidArgumentValueError(error: InvalidArgumentValueError, args: ArgumentsRenderingTree) {\n const argName = error.argument.name\n const selection = args.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n if (selection) {\n selection.getDeepFieldValue(error.argumentPath)?.markAsError()\n }\n\n args.addErrorMessage((colors) => {\n const parts = [`Invalid value for argument \\`${colors.bold(argName)}\\``]\n if (error.underlyingError) {\n parts.push(`: ${error.underlyingError}`)\n }\n parts.push('.')\n if (error.argument.typeNames.length > 0) {\n const expected = joinWithPreposition(\n 'or',\n error.argument.typeNames.map((type) => colors.green(type)),\n )\n parts.push(` Expected ${expected}.`)\n }\n return parts.join('')\n })\n}\n\nfunction applyValueTooLargeError(error: ValueTooLargeError, args: ArgumentsRenderingTree) {\n const argName = error.argument.name\n const selection = args.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n let printedValue: string | undefined\n if (selection) {\n const field = selection.getDeepField(error.argumentPath)\n const value = field?.value\n value?.markAsError()\n if (value instanceof ScalarValue) {\n printedValue = value.text\n }\n }\n\n args.addErrorMessage((colors) => {\n const parts: string[] = ['Unable to fit value']\n if (printedValue) {\n parts.push(colors.red(printedValue))\n }\n parts.push(`into a 64-bit signed integer for field \\`${colors.bold(argName)}\\``)\n\n return parts.join(' ')\n })\n}\n\nfunction applySomeFieldsMissingError(error: SomeFieldsMissingError, args: ArgumentsRenderingTree) {\n const argumentName = error.argumentPath[error.argumentPath.length - 1]\n const selection = args.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n if (selection) {\n const argument = selection.getDeepFieldValue(error.argumentPath)?.asObject()\n if (argument) {\n addInputSuggestions(argument, error.inputType)\n }\n }\n\n args.addErrorMessage((colors) => {\n const parts = [`Argument \\`${colors.bold(argumentName)}\\` of type ${colors.bold(error.inputType.name)} needs`]\n if (error.constraints.minFieldCount === 1) {\n if (error.constraints.requiredFields) {\n parts.push(\n `${colors.green('at least one of')} ${joinWithPreposition(\n 'or',\n error.constraints.requiredFields.map((f) => `\\`${colors.bold(f)}\\``),\n )} arguments.`,\n )\n } else {\n parts.push(`${colors.green('at least one')} argument.`)\n }\n } else {\n parts.push(`${colors.green(`at least ${error.constraints.minFieldCount}`)} arguments.`)\n }\n parts.push(availableOptionsMessage(colors))\n return parts.join(' ')\n })\n}\n\nfunction applyTooManyFieldsGivenError(error: TooManyFieldsGivenError, args: ArgumentsRenderingTree) {\n const argumentName = error.argumentPath[error.argumentPath.length - 1]\n const selection = args.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n let providedArguments: string[] = []\n if (selection) {\n const argument = selection.getDeepFieldValue(error.argumentPath)?.asObject()\n if (argument) {\n argument.markAsError()\n providedArguments = Object.keys(argument.getFields())\n }\n }\n\n args.addErrorMessage((colors) => {\n const parts = [`Argument \\`${colors.bold(argumentName)}\\` of type ${colors.bold(error.inputType.name)} needs`]\n if (error.constraints.minFieldCount === 1 && error.constraints.maxFieldCount == 1) {\n parts.push(`${colors.green('exactly one')} argument,`)\n } else if (error.constraints.maxFieldCount == 1) {\n parts.push(`${colors.green('at most one')} argument,`)\n } else {\n parts.push(`${colors.green(`at most ${error.constraints.maxFieldCount}`)} arguments,`)\n }\n\n parts.push(\n `but you provided ${joinWithPreposition(\n 'and',\n providedArguments.map((arg) => colors.red(arg)),\n )}. Please choose`,\n )\n\n if (error.constraints.maxFieldCount === 1) {\n parts.push('one.')\n } else {\n parts.push(`${error.constraints.maxFieldCount}.`)\n }\n\n return parts.join(' ')\n })\n}\n\nfunction addSelectionSuggestions(selection: ObjectValue, outputType: OutputTypeDescription) {\n for (const field of outputType.fields) {\n if (!selection.hasField(field.name)) {\n selection.addSuggestion(new ObjectFieldSuggestion(field.name, 'true'))\n }\n }\n}\n\nfunction addInclusionSuggestions(selection: ObjectValue, outputType: OutputTypeDescription) {\n for (const field of outputType.fields) {\n if (field.isRelation && !selection.hasField(field.name)) {\n selection.addSuggestion(new ObjectFieldSuggestion(field.name, 'true'))\n }\n }\n}\n\nfunction addOmissionSuggestions(selection: ObjectValue, outputType: OutputTypeDescription) {\n for (const field of outputType.fields) {\n if (!selection.hasField(field.name) && !field.isRelation) {\n selection.addSuggestion(new ObjectFieldSuggestion(field.name, 'true'))\n }\n }\n}\n\nfunction addArgumentsSuggestions(argumentsParent: ObjectValue, args: ArgumentDescription[]) {\n for (const arg of args) {\n if (!argumentsParent.hasField(arg.name)) {\n argumentsParent.addSuggestion(new ObjectFieldSuggestion(arg.name, arg.typeNames.join(' | ')))\n }\n }\n}\n\nfunction locateSelectionField(selectionPath: string[], argsTree: ArgumentsRenderingTree) {\n const [parentPath, fieldName] = splitPath(selectionPath)\n\n const subSelection = argsTree.arguments.getDeepSubSelectionValue(parentPath)?.asObject()\n if (!subSelection) {\n return { parentKind: 'unknown' as const, fieldName }\n }\n const select = subSelection.getFieldValue('select')?.asObject()\n const include = subSelection.getFieldValue('include')?.asObject()\n const omit = subSelection.getFieldValue('omit')?.asObject()\n let field = select?.getField(fieldName)\n if (select && field) {\n return { parentKind: 'select' as const, parent: select, field, fieldName }\n }\n field = include?.getField(fieldName)\n if (include && field) {\n return { parentKind: 'include' as const, field, parent: include, fieldName }\n }\n\n field = omit?.getField(fieldName)\n if (omit && field) {\n return { parentKind: 'omit' as const, field, parent: omit, fieldName }\n }\n return { parentKind: 'unknown' as const, fieldName }\n}\n\nfunction addInputSuggestions(parent: ObjectValue, inputType: InputTypeDescription) {\n if (inputType.kind !== 'object') {\n return\n }\n\n for (const field of inputType.fields) {\n if (!parent.hasField(field.name)) {\n parent.addSuggestion(new ObjectFieldSuggestion(field.name, field.typeNames.join(' | ')))\n }\n }\n}\n\nfunction splitPath(path: string[]): [parentPath: string[], fieldName: string] {\n const selectionPath = [...path]\n const fieldName = selectionPath.pop()\n if (!fieldName) {\n throw new Error('unexpected empty path')\n }\n return [selectionPath, fieldName]\n}\n\nfunction availableOptionsMessage({ green, enabled }: Colors) {\n return `Available options are ` + (enabled ? `listed in ${green('green')}` : `marked with ?`) + '.'\n}\n\nfunction joinWithPreposition(preposition: 'and' | 'or', items: string[]): string {\n if (items.length === 1) {\n return items[0]\n }\n const itemsCopy = [...items]\n const lastItem = itemsCopy.pop()\n return `${itemsCopy.join(', ')} ${preposition} ${lastItem}`\n}\n\n/**\n * Options with edit distance above this value will never be suggested\n */\nconst MAX_EDIT_DISTANCE = 3\n\nfunction getSuggestion(str: string, options: string[]): string | undefined {\n let minDistance = Infinity\n let result: string | undefined\n\n for (const option of options) {\n const editDistance = levenshtein(str, option)\n if (editDistance > MAX_EDIT_DISTANCE) {\n continue\n }\n if (editDistance < minDistance) {\n minDistance = editDistance\n result = option\n }\n }\n return result\n}\n", "import { maxWithComparator } from '@prisma/internals'\n\nimport { EngineValidationError, InvalidArgumentTypeError, UnionError } from '../engines'\nimport { GlobalOmitOptions } from '../jsonProtocol/serializeJsonQuery'\nimport { applyValidationError } from './applyValidationError'\nimport { ArgumentsRenderingTree } from './ArgumentsRenderingTree'\n\ntype NonUnionError = Exclude<EngineValidationError, UnionError>\n\n/**\n * When a particular field has multiple allowed types on the schema level\n * and none of them match users input, engine returns special kind of error: UnionError.\n * This error acts as a container for individual errors for each non-matching type.\n * In that case, we need to make a guess which of the errors corresponds users intent the most.\n * General algorithm of processing them is the following:\n * - flatten all nested errors and get a single list of all possible errors\n * - merge individual InvalidArgumentType errors at the same path\n * - pick the best error based on combined argument and selection paths length and type of the error.\n *\n * For details of each step, see other comments in this file.\n * @param error\n * @param args\n */\nexport function applyUnionError(error: UnionError, args: ArgumentsRenderingTree, globalOmit?: GlobalOmitOptions) {\n const allErrors = flattenUnionError(error)\n const merged = mergeInvalidArgumentTypeErrors(allErrors)\n const bestError = getBestScoringError(merged)\n if (bestError) {\n applyValidationError(bestError, args, globalOmit)\n } else {\n args.addErrorMessage(() => 'Unknown error')\n }\n}\n\nfunction flattenUnionError(error: UnionError): NonUnionError[] {\n return error.errors.flatMap((error) => {\n if (error.kind === 'Union') {\n return flattenUnionError(error)\n }\n return [error]\n })\n}\n\n/**\n * Iterates over provided error list and merges all InvalidArgumentType\n * with matching selectionPath and argumentPath into one. For example,\n * if the list has an error, saying that `where.arg` does not match `Int`\n * and another, saying that `where.arg` does not match IntFilter, resulting\n * list will contain a single error for `where.arg` saying it does not\n * match `Int | IntFilter`\n * @param errorList\n * @returns\n */\nfunction mergeInvalidArgumentTypeErrors(errorList: NonUnionError[]) {\n const invalidArgsError = new Map<string, InvalidArgumentTypeError>()\n const result: NonUnionError[] = []\n\n for (const error of errorList) {\n if (error.kind !== 'InvalidArgumentType') {\n result.push(error)\n continue\n }\n\n const key = `${error.selectionPath.join('.')}:${error.argumentPath.join('.')}`\n const prevError = invalidArgsError.get(key)\n if (!prevError) {\n invalidArgsError.set(key, error)\n } else {\n invalidArgsError.set(key, {\n ...error,\n argument: {\n ...error.argument,\n typeNames: uniqueConcat(prevError.argument.typeNames, error.argument.typeNames),\n },\n })\n }\n }\n\n result.push(...invalidArgsError.values())\n return result\n}\n\nfunction uniqueConcat<T>(head: T[], tail: T[]): T[] {\n return [...new Set(head.concat(tail))]\n}\n\n/**\n * Function that attempts to pick the best error from the list\n * by ranking them. In most cases, highest ranking error would be the one\n * which has the longest combined \"selectionPath\" + \"argumentPath\". Justification\n * for that is that type that made it deeper into validation tree before failing\n * is probably closer to the one user actually wanted to do.\n *\n * However, if two errors are at the same depth level, we introduce additional ranking based\n * on error type. See `getErrorTypeScore` function for details\n * @param errors\n * @returns\n */\nfunction getBestScoringError(errors: NonUnionError[]) {\n return maxWithComparator(errors, (errorA, errorB) => {\n const aPathLength = getCombinedPathLength(errorA)\n const bPathLength = getCombinedPathLength(errorB)\n if (aPathLength !== bPathLength) {\n return aPathLength - bPathLength\n }\n return getErrorTypeScore(errorA) - getErrorTypeScore(errorB)\n })\n}\n\nfunction getCombinedPathLength(error: EngineValidationError) {\n let score = 0\n if (Array.isArray(error['selectionPath'])) {\n score += error['selectionPath'].length\n }\n\n if (Array.isArray(error['argumentPath'])) {\n score += error['argumentPath'].length\n }\n return score\n}\n\n/**\n * Function is invoked to determine most relevant error based on its type.\n * Specific numbers returned from this function do not really matter, it's only\n * important how they compare relatively to each other.\n *\n * Current logic is:\n * - InvalidArgumentValue/ValueTooLarge is treated as the best possible error to display\n * since when it is present we know that the field causing the error is defined on the schema\n * and provided value has correct type, it's just that value violates some other constraint.\n * - Next candidate is `InvalidArgumentType` error. We know the field user specified can exists in\n * this spot, it's just that value provided has incorrect type.\n * - All other engine-side errors follow. At that point it's difficult to say which of them is more relevant,\n * so we treat them equally. We might adjust this logic in the future.\n * - RequiredArgumentMissing is penalized because this error is often used to disambiguate\n * union types and what is required in one arm of the union might be fine to leave out in another\n * @param error\n * @returns\n */\nfunction getErrorTypeScore(error: EngineValidationError): number {\n switch (error.kind) {\n case 'InvalidArgumentValue':\n case 'ValueTooLarge':\n return 20\n case 'InvalidArgumentType':\n return 10\n case 'RequiredArgumentMissing':\n return -10\n default:\n return 0\n }\n}\n", "import { ErrorBasicBuilder, ErrorWriter } from './base'\nimport { SuggestionObjectValue } from './SuggestionObjectValue'\n\nexport class ObjectFieldSuggestion implements ErrorBasicBuilder {\n public isRequired = false\n constructor(\n readonly name: string,\n readonly value: string | SuggestionObjectValue,\n ) {}\n\n makeRequired() {\n this.isRequired = true\n return this\n }\n\n write(writer: ErrorWriter): void {\n const {\n colors: { green },\n } = writer.context\n\n writer.addMarginSymbol(green(this.isRequired ? '+' : '?'))\n writer.write(green(this.name))\n\n if (!this.isRequired) {\n writer.write(green('?'))\n }\n\n writer.write(green(`: `))\n if (typeof this.value === 'string') {\n writer.write(green(this.value))\n } else {\n writer.write(this.value)\n }\n }\n}\n", "export * from './AnyDeclarationBuilder'\nexport * from './ArraySpread'\nexport * from './ArrayType'\nexport * from './BasicBuilder'\nexport * from './Class'\nexport * from './ConditionalType'\nexport * from './ConstDeclaration'\nexport * from './DocComment'\nexport * from './Export'\nexport * from './ExportFrom'\nexport * from './File'\nexport * from './FunctionCall'\nexport * from './FunctionType'\nexport * from './GenericParameter'\nexport * from './helpers'\nexport * from './Import'\nexport * from './Interface'\nexport * from './IntersectionType'\nexport * from './KeyofType'\nexport * from './KeyType'\nexport * from './Method'\nexport * from './NamedType'\nexport * from './NamedValue'\nexport * from './NamespaceDeclaration'\nexport * from './ObjectType'\nexport * from './Parameter'\nexport * from './PrimitiveType'\nexport * from './Property'\nexport * from './stringify'\nexport * from './StringLiteralType'\nexport * from './TupleType'\nexport * from './TypeBuilder'\nexport * from './TypeDeclaration'\nexport * from './UnionType'\nexport * from './ValueBuilder'\nexport * from './WellKnownSymbol'\nexport * from './Writer'\n", "import type { BasicBuilder } from './BasicBuilder'\n\nexport const INDENT_SIZE = 2\n/**\n * Helper class for building long multi-line formatted strings from building blocks.\n * Can use either plain strings or `Builder` objects, that would encapsulate formatting logic.\n */\nexport class Writer<ContextType = undefined> {\n private lines: string[] = []\n private currentLine = ''\n private currentIndent = 0\n private marginSymbol?: string\n private afterNextNewLineCallback?: () => void\n\n constructor(\n startingIndent = 0,\n readonly context: ContextType,\n ) {\n this.currentIndent = startingIndent\n }\n\n /**\n * Adds provided value to the current line. Does not end the line.\n *\n * @param value\n * @returns\n */\n write(value: string | BasicBuilder<ContextType>): this {\n if (typeof value === 'string') {\n this.currentLine += value\n } else {\n value.write(this)\n }\n return this\n }\n\n /**\n * Adds several `values` to the current line, separated by `separator`. Both values and separator\n * can also be `Builder` instances for more advanced formatting.\n *\n * @param separator\n * @param values\n * @param writeItem allow to customize how individual item is written\n * @returns\n */\n writeJoined<T extends string | BasicBuilder<ContextType>>(\n separator: string | BasicBuilder<ContextType>,\n values: T[],\n writeItem: (item: T, writer: this) => void = (item, w) => w.write(item),\n ): this {\n const last = values.length - 1\n for (let i = 0; i < values.length; i++) {\n writeItem(values[i], this)\n if (i !== last) {\n this.write(separator)\n }\n }\n return this\n }\n\n /**\n * Adds a string to current line, flushes current line and starts a new line.\n * @param line\n * @returns\n */\n writeLine(line: string | BasicBuilder<ContextType>): this {\n return this.write(line).newLine()\n }\n\n /**\n * Flushes current line and starts a new line. New line starts at previously configured indentation level\n * @returns\n */\n newLine(): this {\n this.lines.push(this.indentedCurrentLine())\n this.currentLine = ''\n this.marginSymbol = undefined\n\n const afterNextNewLineCallback = this.afterNextNewLineCallback\n this.afterNextNewLineCallback = undefined\n afterNextNewLineCallback?.()\n return this\n }\n\n /**\n * Increases indentation level by 1, calls provided callback and then decreases indentation again.\n * Could be used for writing indented blocks of text:\n *\n * @example\n * ```ts\n * writer\n * .writeLine('{')\n * .withIndent(() => {\n * writer.writeLine('foo: 123');\n * writer.writeLine('bar: 456');\n * })\n * .writeLine('}')\n * ```\n * @param callback\n * @returns\n */\n withIndent(callback: (writer: this) => void): this {\n this.indent()\n callback(this)\n this.unindent()\n return this\n }\n\n /**\n * Calls provided callback next time when new line is started.\n * Callback is called after old line have already been flushed and a new\n * line have been started. Can be used for adding \"between the lines\" decorations,\n * such as underlines.\n *\n * @param callback\n * @returns\n */\n afterNextNewline(callback: () => void) {\n this.afterNextNewLineCallback = callback\n return this\n }\n\n /**\n * Increases indentation level of the current line by 1\n * @returns\n */\n indent(): this {\n this.currentIndent++\n return this\n }\n\n /**\n * Decreases indentation level of the current line by 1, if it is possible\n * @returns\n */\n unindent(): this {\n if (this.currentIndent > 0) {\n this.currentIndent--\n }\n return this\n }\n\n /**\n * Adds a symbol, that will replace the first character of the current line (including indentation)\n * when it is flushed. Can be used for adding markers to the line.\n *\n * Note: if indentation level of the line is 0, it will replace the first actually printed character\n * of the line. Use with caution.\n * @param symbol\n * @returns\n */\n addMarginSymbol(symbol: string): this {\n this.marginSymbol = symbol\n return this\n }\n\n toString() {\n return this.lines.concat(this.indentedCurrentLine()).join('\\n')\n }\n\n getCurrentLineLength() {\n return this.currentLine.length\n }\n\n private indentedCurrentLine(): string {\n const line = this.currentLine.padStart(this.currentLine.length + INDENT_SIZE * this.currentIndent)\n if (this.marginSymbol) {\n return this.marginSymbol + line.slice(1)\n }\n return line\n }\n}\n", "import { ErrorBasicBuilder, ErrorWriter } from './base'\nimport { Field } from './Field'\nimport { Value } from './Value'\n\nexport class ArrayField implements ErrorBasicBuilder, Field {\n constructor(public value: Value) {}\n write(writer: ErrorWriter): void {\n writer.write(this.value)\n }\n\n markAsError(): void {\n this.value.markAsError()\n }\n}\n", "import { BasicBuilder, Writer } from '@prisma/ts-builders'\nimport { bold, dim, green, red } from 'kleur/colors'\n\ntype ColorFn = (str: string) => string\nexport type Colors = {\n bold: ColorFn\n red: ColorFn\n green: ColorFn\n dim: ColorFn\n // if false, all color functions are useless\n readonly enabled: boolean\n}\n\nconst noop = (str: string) => str\n\nexport const inactiveColors: Colors = {\n bold: noop,\n red: noop,\n green: noop,\n dim: noop,\n enabled: false,\n}\n\nexport const activeColors: Colors = {\n bold,\n red,\n green,\n dim,\n enabled: true,\n}\n\nexport type ErrorRenderContext = {\n colors: Colors\n}\n\nexport type ErrorWriter = Writer<ErrorRenderContext>\nexport type ErrorBasicBuilder = BasicBuilder<ErrorRenderContext>\n\nexport const fieldsSeparator: ErrorBasicBuilder = {\n write(writer) {\n writer.writeLine(',')\n },\n}\n", "import { ErrorBasicBuilder, ErrorWriter } from './base'\n\nexport type ColorFn = (str: string) => string\n\nexport class FormattedString implements ErrorBasicBuilder {\n private isUnderlined = false\n private color: ColorFn = (str) => str\n constructor(public contents: string) {}\n\n underline(): this {\n this.isUnderlined = true\n return this\n }\n\n setColor(color: ColorFn): this {\n this.color = color\n return this\n }\n\n write(writer: ErrorWriter): void {\n const paddingSize = writer.getCurrentLineLength()\n writer.write(this.color(this.contents))\n if (this.isUnderlined) {\n writer.afterNextNewline(() => {\n writer.write(' '.repeat(paddingSize)).writeLine(this.color('~'.repeat(this.contents.length)))\n })\n }\n }\n}\n", "import { ErrorBasicBuilder, ErrorWriter } from './base'\nimport { ObjectValue } from './ObjectValue'\n\nexport abstract class Value implements ErrorBasicBuilder {\n abstract write(writer: ErrorWriter): void\n\n /**\n * Returns total width the value when it is rendered. Used\n * for determining underline width.\n */\n abstract getPrintWidth(): number\n\n public hasError = false\n\n markAsError(): this {\n this.hasError = true\n return this\n }\n\n abstract asObject(): ObjectValue | undefined\n}\n", "import { INDENT_SIZE } from '@prisma/ts-builders'\n\nimport { ArrayField } from './ArrayField'\nimport { ErrorWriter, fieldsSeparator } from './base'\nimport { FormattedString } from './FormattedString'\nimport { Value } from './Value'\n\nexport class ArrayValue extends Value {\n private items: ArrayField[] = []\n\n addItem(item: Value): this {\n this.items.push(new ArrayField(item))\n return this\n }\n\n getField(index: number): ArrayField | undefined {\n return this.items[index]\n }\n\n override getPrintWidth(): number {\n if (this.items.length === 0) {\n return 2\n }\n const maxItemWidth = Math.max(...this.items.map((item) => item.value.getPrintWidth()))\n return maxItemWidth + INDENT_SIZE\n }\n\n override write(writer: ErrorWriter): void {\n if (this.items.length === 0) {\n this.writeEmpty(writer)\n return\n }\n this.writeWithItems(writer)\n }\n\n private writeEmpty(writer: ErrorWriter) {\n const output = new FormattedString('[]')\n if (this.hasError) {\n output.setColor(writer.context.colors.red).underline()\n }\n writer.write(output)\n }\n\n private writeWithItems(writer: ErrorWriter) {\n const { colors } = writer.context\n\n writer\n .writeLine('[')\n .withIndent(() => writer.writeJoined(fieldsSeparator, this.items).newLine())\n .write(']')\n\n if (this.hasError) {\n writer.afterNextNewline(() => {\n writer.writeLine(colors.red('~'.repeat(this.getPrintWidth())))\n })\n }\n }\n\n override asObject(): undefined {\n return undefined\n }\n}\n", "import { INDENT_SIZE } from '@prisma/ts-builders'\n\nimport { ArrayValue } from './ArrayValue'\nimport { ErrorWriter, fieldsSeparator } from './base'\nimport { Field } from './Field'\nimport { FormattedString } from './FormattedString'\nimport { ObjectField } from './ObjectField'\nimport { ObjectFieldSuggestion } from './ObjectFieldSuggestion'\nimport { Value } from './Value'\n\ntype SelectionParent = {\n kind: 'include' | 'select'\n value: ObjectValue\n}\n\n/**\n * Class for representing object value within rendering tree. Also used for accessing\n * different fields of the object.\n *\n * Terminology used within:\n * - selection parent = either `select` or `include` property value. For example for object\n * `{ select: { posts: true }}`, selection parent is `{ posts: true }`\n * - sub selection: value of a property of selection parent. Can be deep. In that case, specified\n * path is expected to not contain either `select` or `include` values in between (the way engine reports `selectionPath`).\n * For example, for this query:\n *\n * {\n * include: {\n * posts: {\n * select: { attachments: { where: { published: true }} }\n * }\n * }\n * }\n * Value of sub selection at path [posts, attachments] is { where: { published: true }}\n */\nexport class ObjectValue extends Value {\n private fields: Record<string, ObjectField> = {}\n private suggestions: ObjectFieldSuggestion[] = []\n\n addField(field: ObjectField) {\n this.fields[field.name] = field\n }\n\n addSuggestion(suggestion: ObjectFieldSuggestion) {\n this.suggestions.push(suggestion)\n }\n\n getField(key: string): ObjectField | undefined {\n return this.fields[key]\n }\n\n getDeepField(path: string[]): Field | undefined {\n const [head, ...tail] = path\n const firstField = this.getField(head)\n if (!firstField) {\n return undefined\n }\n let field: Field = firstField\n for (const segment of tail) {\n let nextField: Field | undefined\n\n if (field.value instanceof ObjectValue) {\n nextField = field.value.getField(segment)\n } else if (field.value instanceof ArrayValue) {\n nextField = field.value.getField(Number(segment))\n }\n if (!nextField) {\n return undefined\n }\n field = nextField\n }\n return field\n }\n\n getDeepFieldValue(path: string[]) {\n if (path.length === 0) {\n return this\n }\n return this.getDeepField(path)?.value\n }\n\n hasField(key: string) {\n return Boolean(this.getField(key))\n }\n\n removeAllFields() {\n this.fields = {}\n }\n\n removeField(key: string) {\n delete this.fields[key]\n }\n\n getFields() {\n return this.fields\n }\n\n isEmpty(): boolean {\n return Object.keys(this.fields).length === 0\n }\n\n getFieldValue(key: string): Value | undefined {\n return this.getField(key)?.value\n }\n\n getDeepSubSelectionValue(path: string[]): Value | undefined {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let selection: Value = this\n for (const segment of path) {\n if (!(selection instanceof ObjectValue)) {\n return undefined\n }\n const next = selection.getSubSelectionValue(segment)\n if (!next) {\n return undefined\n }\n\n selection = next\n }\n\n return selection\n }\n\n getDeepSelectionParent(path: string[]): SelectionParent | undefined {\n const thisParent = this.getSelectionParent()\n if (!thisParent) {\n return undefined\n }\n\n let parent = thisParent\n\n for (const segment of path) {\n const next = parent.value.getFieldValue(segment)\n if (!next || !(next instanceof ObjectValue)) {\n return undefined\n }\n\n const nextParent = next.getSelectionParent()\n if (!nextParent) {\n return undefined\n }\n parent = nextParent\n }\n\n return parent\n }\n\n getSelectionParent(): SelectionParent | undefined {\n const select = this.getField('select')?.value.asObject()\n if (select) {\n return { kind: 'select', value: select }\n }\n\n const include = this.getField('include')?.value.asObject()\n if (include) {\n return { kind: 'include', value: include }\n }\n return undefined\n }\n\n getSubSelectionValue(key: string): Value | undefined {\n return this.getSelectionParent()?.value.fields[key].value\n }\n\n override getPrintWidth(): number {\n const fields = Object.values(this.fields)\n if (fields.length == 0) {\n return 2 // {}\n }\n const maxFieldWidth = Math.max(...fields.map((f) => f.getPrintWidth()))\n return maxFieldWidth + INDENT_SIZE\n }\n\n override write(writer: ErrorWriter): void {\n const fields = Object.values(this.fields)\n if (fields.length === 0 && this.suggestions.length === 0) {\n this.writeEmpty(writer)\n return\n }\n\n this.writeWithContents(writer, fields)\n }\n\n override asObject(): ObjectValue {\n return this\n }\n\n private writeEmpty(writer: ErrorWriter) {\n const output = new FormattedString('{}')\n if (this.hasError) {\n output.setColor(writer.context.colors.red).underline()\n }\n\n writer.write(output)\n }\n\n private writeWithContents(writer: ErrorWriter, fields: ObjectField[]) {\n writer.writeLine('{').withIndent(() => {\n writer.writeJoined(fieldsSeparator, [...fields, ...this.suggestions]).newLine()\n })\n\n writer.write('}')\n if (this.hasError) {\n writer.afterNextNewline(() => {\n writer.writeLine(writer.context.colors.red('~'.repeat(this.getPrintWidth())))\n })\n }\n }\n}\n", "import { ErrorWriter } from './base'\nimport { FormattedString } from './FormattedString'\nimport { Value } from './Value'\n\nexport class ScalarValue extends Value {\n constructor(readonly text: string) {\n super()\n }\n\n override getPrintWidth(): number {\n return this.text.length\n }\n\n override write(writer: ErrorWriter): void {\n const string = new FormattedString(this.text)\n if (this.hasError) {\n string.underline().setColor(writer.context.colors.red)\n }\n writer.write(string)\n }\n\n override asObject(): undefined {\n return undefined\n }\n}\n", "import { ErrorBasicBuilder, ErrorWriter, fieldsSeparator } from './base'\n\nexport class SuggestionObjectValue implements ErrorBasicBuilder {\n private fields: ErrorBasicBuilder[] = []\n\n addField(name: string, value: string) {\n this.fields.push({\n write(writer) {\n const { green, dim } = writer.context.colors\n writer.write(green(dim(`${name}: ${value}`))).addMarginSymbol(green(dim('+')))\n },\n })\n return this\n }\n\n write(writer: ErrorWriter): void {\n const {\n colors: { green },\n } = writer.context\n writer\n .writeLine(green('{'))\n .withIndent(() => {\n writer.writeJoined(fieldsSeparator, this.fields).newLine()\n })\n .write(green('}'))\n .addMarginSymbol(green('+'))\n }\n}\n", "import { uncapitalize } from '@prisma/client-common'\nimport { ObjectEnumValue } from '@prisma/client-runtime-utils'\nimport { Writer } from '@prisma/ts-builders'\n\nimport { ErrorFormat } from '../../getPrismaClient'\nimport { isValidDate } from '../../utils/date'\nimport { isDecimalJsLike } from '../../utils/decimalJsLike'\nimport { isFieldRef } from '../model/FieldRef'\nimport { ArrayValue } from './ArrayValue'\nimport { activeColors, Colors, ErrorBasicBuilder, ErrorWriter, inactiveColors } from './base'\nimport { ObjectField } from './ObjectField'\nimport { ObjectValue } from './ObjectValue'\nimport { ScalarValue } from './ScalarValue'\n\ntype MessageRender = (colors: Colors) => string\n\nexport class ArgumentsRenderingTree implements ErrorBasicBuilder {\n readonly arguments: ObjectValue\n private errorMessages: MessageRender[] = []\n\n constructor(args: ObjectValue) {\n this.arguments = args\n }\n\n write(writer: ErrorWriter): void {\n writer.write(this.arguments)\n }\n\n addErrorMessage(renderer: MessageRender) {\n this.errorMessages.push(renderer)\n }\n\n renderAllMessages(colors: Colors): string {\n return this.errorMessages.map((messageRenderer) => messageRenderer(colors)).join('\\n')\n }\n}\n\n/**\n * Given JS call arguments, produces rendering tree for outputting rich errors into the console\n * Difference between rendering tree and plain object is that fields and values can have different attributes:\n * colors, underlines, markers on the margins. `applyValidationError` function will then apply specific formatting\n * to the rendering tree.\n *\n * @param args\n * @returns\n */\nexport function buildArgumentsRenderingTree(args: Record<PropertyKey, unknown>): ArgumentsRenderingTree {\n return new ArgumentsRenderingTree(buildInputObject(args))\n}\n\nfunction buildInputObject(inputObject: Record<PropertyKey, unknown>) {\n const object = new ObjectValue()\n\n for (const [key, value] of Object.entries(inputObject)) {\n const field = new ObjectField(key, buildInputValue(value))\n object.addField(field)\n }\n return object\n}\n\nfunction buildInputValue(value: unknown) {\n if (typeof value === 'string') {\n return new ScalarValue(JSON.stringify(value))\n }\n\n if (typeof value === 'number' || typeof value === 'boolean') {\n return new ScalarValue(String(value))\n }\n\n if (typeof value === 'bigint') {\n return new ScalarValue(`${value}n`)\n }\n\n if (value === null) {\n return new ScalarValue('null')\n }\n\n if (value === undefined) {\n return new ScalarValue('undefined')\n }\n\n if (isDecimalJsLike(value)) {\n return new ScalarValue(`new Prisma.Decimal(\"${value.toFixed()}\")`)\n }\n\n if (value instanceof Uint8Array) {\n if (Buffer.isBuffer(value)) {\n return new ScalarValue(`Buffer.alloc(${value.byteLength})`)\n }\n return new ScalarValue(`new Uint8Array(${value.byteLength})`)\n }\n\n if (value instanceof Date) {\n const dateStr = isValidDate(value) ? value.toISOString() : 'Invalid Date'\n return new ScalarValue(`new Date(\"${dateStr}\")`)\n }\n\n if (value instanceof ObjectEnumValue) {\n return new ScalarValue(`Prisma.${value._getName()}`)\n }\n\n if (isFieldRef(value)) {\n return new ScalarValue(`prisma.${uncapitalize(value.modelName)}.$fields.${value.name}`)\n }\n\n if (Array.isArray(value)) {\n return buildInputArray(value)\n }\n\n if (typeof value === 'object') {\n return buildInputObject(value as Record<PropertyKey, unknown>)\n }\n\n return new ScalarValue(Object.prototype.toString.call(value))\n}\n\nfunction buildInputArray(array: unknown[]) {\n const result = new ArrayValue()\n for (const item of array) {\n result.addItem(buildInputValue(item))\n }\n return result\n}\n\nexport function renderArgsTree(argsTree: ArgumentsRenderingTree, errorFormat: ErrorFormat) {\n const colors = errorFormat === 'pretty' ? activeColors : inactiveColors\n\n const message = argsTree.renderAllMessages(colors)\n const args = new Writer(0, { colors }).write(argsTree).toString()\n\n return { message, args }\n}\n", "import { FieldRef } from '../types/exported/FieldRef'\n\nexport class FieldRefImpl<Model, FieldType> implements FieldRef<Model, FieldType> {\n public readonly modelName: Model\n public readonly name: string\n public readonly typeName: FieldType\n public readonly isList: boolean\n public readonly isEnum: boolean\n\n constructor(modelName: Model, name: string, fieldType: FieldType, isList: boolean, isEnum: boolean) {\n this.modelName = modelName\n this.name = name\n this.typeName = fieldType\n this.isList = isList\n this.isEnum = isEnum\n }\n\n _toGraphQLInputType() {\n const listPrefix = this.isList ? `List` : ''\n const enumPrefix = this.isEnum ? 'Enum' : ''\n\n return `${listPrefix}${enumPrefix}${this.typeName}FieldRefInput<${this.modelName}>`\n }\n}\n\nexport function isFieldRef(value: unknown): value is FieldRef<string, unknown> {\n return value instanceof FieldRefImpl\n}\n", "import { ErrorBasicBuilder, ErrorWriter } from './base'\nimport { Field } from './Field'\nimport { FormattedString } from './FormattedString'\nimport { Value } from './Value'\n\nconst separator = ': '\nexport class ObjectField implements ErrorBasicBuilder, Field {\n hasError = false\n constructor(\n readonly name: string,\n public value: Value,\n ) {}\n\n markAsError() {\n this.hasError = true\n }\n\n getPrintWidth() {\n return this.name.length + this.value.getPrintWidth() + separator.length\n }\n\n write(writer: ErrorWriter): void {\n const name = new FormattedString(this.name)\n if (this.hasError) {\n name.underline().setColor(writer.context.colors.red)\n }\n writer.write(name).write(separator).write(this.value)\n }\n}\n", "/**\n * Transforms a model name coming from the DMMF to a runtime model name.\n * @param name\n * @returns\n */\nexport function dmmfToJSModelName(name: string) {\n return name.replace(/^./, (str) => str.toLowerCase())\n}\n", "import { Cache } from '@prisma/client-common'\nimport { mapObjectValues } from '@prisma/internals'\n\nimport { dmmfToJSModelName } from '../model/utils/dmmfToJSModelName'\nimport { ExtensionArgs, ResultArg, ResultArgsFieldCompute } from '../types/exported/ExtensionArgs'\nimport { Omission, Selection } from '../types/exported/JsApi'\n\nexport type ComputedField = {\n name: string\n needs: string[]\n compute: ResultArgsFieldCompute\n}\n\nexport type ComputedFieldsMap = {\n [fieldName: string]: ComputedField\n}\n\n/**\n * Given the list of previously resolved computed fields, new extension and dmmf model name, produces a map\n * of all computed fields that may be applied to this model, accounting for all previous and past extensions.\n *\n * All naming conflicts which could be produced by the plain list of extensions are resolved as follows:\n * - extension, that declared later always wins\n * - in a single extension, specific model takes precedence over $allModels\n *\n * Additionally, resolves all `needs` dependencies down to the model fields. For example,\n * if `nameAndTitle` field depends on `fullName` computed field and `title` model field and\n * `fullName` field depends on `firstName` and `lastName` field, full list of `nameAndTitle` dependencies\n * would be `firstName`, `lastName`, `title`.\n * @param previousComputedFields\n * @param extension\n * @param dmmfModelName\n * @returns\n */\nexport function getComputedFields(\n previousComputedFields: ComputedFieldsMap | undefined,\n extension: ExtensionArgs,\n dmmfModelName: string,\n) {\n const jsName = dmmfToJSModelName(dmmfModelName)\n if (!extension.result || !(extension.result.$allModels || extension.result[jsName])) {\n return previousComputedFields\n }\n\n return resolveDependencies({\n ...previousComputedFields,\n ...getComputedFieldsFromModel(extension.name, previousComputedFields, extension.result.$allModels),\n ...getComputedFieldsFromModel(extension.name, previousComputedFields, extension.result[jsName]),\n })\n}\n\nexport function resolveDependencies(computedFields: ComputedFieldsMap): ComputedFieldsMap {\n const cache = new Cache<string, string[]>()\n const resolveNeeds = (fieldName: string, visitedFields: Set<string>) => {\n return cache.getOrCreate(fieldName, () => {\n if (visitedFields.has(fieldName)) {\n return [fieldName]\n }\n visitedFields.add(fieldName)\n if (!computedFields[fieldName]) {\n return [fieldName]\n }\n return computedFields[fieldName].needs.flatMap((fieldDep) => resolveNeeds(fieldDep, visitedFields))\n })\n }\n\n return mapObjectValues(computedFields, (field) => {\n return {\n ...field,\n needs: resolveNeeds(field.name, new Set()),\n }\n })\n}\n\nfunction getComputedFieldsFromModel(\n name: string | undefined,\n previousComputedFields: ComputedFieldsMap | undefined,\n modelResult: ResultArg | undefined,\n): ComputedFieldsMap {\n if (!modelResult) {\n return {}\n }\n\n return mapObjectValues(modelResult, ({ needs, compute }, fieldName) => ({\n name: fieldName,\n needs: needs ? Object.keys(needs).filter((key) => needs[key]) : [],\n compute: composeCompute(previousComputedFields, fieldName, compute),\n }))\n}\n\nfunction composeCompute(\n previousComputedFields: ComputedFieldsMap | undefined,\n fieldName: string,\n nextCompute: ResultArgsFieldCompute,\n): ResultArgsFieldCompute {\n const previousCompute = previousComputedFields?.[fieldName]?.compute\n if (!previousCompute) {\n return nextCompute\n }\n return (model) => {\n return nextCompute({ ...model, [fieldName]: previousCompute(model) })\n }\n}\n\nexport function computeEngineSideSelection(\n selection: Selection,\n computedFields: ComputedFieldsMap | undefined,\n): Selection {\n if (!computedFields) {\n return selection\n }\n const result = { ...selection }\n\n for (const field of Object.values(computedFields)) {\n if (!selection[field.name]) {\n continue\n }\n\n for (const dependency of field.needs) {\n result[dependency] = true\n }\n }\n return result\n}\n\n/**\n * Given user-supplied omissions, computes the results to send to the engine, taking\n * into account dependencies of the computed field. Consider following example:\n *\n * ```\n * const xprisma = prisma.$extends({\n * result: {\n * user: {\n * sanitizedPassword: {\n * needs: { password: true },\n * compute(user) {\n * return sanitze(user.password)\n * },\n * },\n * },\n * },\n * })\n *\n * const user = await xprisma.user.findFirstOrThrow({\n * omit: {\n * password: true,\n * },\n * })\n * ```\n *\n * In that case, user wants to omit the `password` but not `sanitizedPassword`.\n * Since `sanitizedPassword` can not be computed without `password`, we can not let\n * the engine handle omission in this case - we have to still query `password` from the\n * database and omit it on the client, after computing `sanitizedPassword`.\n *\n * This function removes the omission (thus, including the field into result set) if it is a dependency of\n * a non-omitted computed field. Client-side omission after we get a response is handled by `applyResultExtensions`\n *\n * @param omission\n * @param computedFields\n * @returns\n */\nexport function computeEngineSideOmissions(\n omission: Omission,\n computedFields: ComputedFieldsMap | undefined,\n): Omission {\n if (!computedFields) {\n return omission\n }\n const result = { ...omission }\n\n for (const field of Object.values(computedFields)) {\n if (omission[field.name]) {\n continue\n }\n\n for (const dependency of field.needs) {\n delete result[dependency]\n }\n }\n return result\n}\n", "import { Cache, lazyProperty } from '@prisma/client-common'\n\nimport { dmmfToJSModelName } from '../model/utils/dmmfToJSModelName'\nimport { ClientArg, ExtensionArgs, ModelArg, QueryOptionsCb } from '../types/exported/ExtensionArgs'\nimport { BatchQueryOptionsCb, QueryOptionsPrivate } from '../types/internal/ExtensionsInternalArgs'\nimport { ComputedFieldsMap, getComputedFields } from './resultUtils'\n\nclass MergedExtensionsListNode {\n private computedFieldsCache = new Cache<string, ComputedFieldsMap | undefined>()\n private modelExtensionsCache = new Cache<string, ModelArg | undefined>()\n private queryCallbacksCache = new Cache<string, QueryOptionsCb[]>()\n\n private clientExtensions = lazyProperty(() => {\n if (!this.extension.client) {\n return this.previous?.getAllClientExtensions()\n }\n\n return {\n ...this.previous?.getAllClientExtensions(),\n ...this.extension.client,\n }\n })\n\n private batchCallbacks = lazyProperty(() => {\n const previous: BatchQueryOptionsCb[] = this.previous?.getAllBatchQueryCallbacks() ?? []\n const newCb = (this.extension as QueryOptionsPrivate).query?.$__internalBatch\n if (!newCb) {\n return previous\n }\n return previous.concat(newCb)\n })\n\n constructor(\n public extension: ExtensionArgs,\n public previous?: MergedExtensionsListNode,\n ) {}\n\n getAllComputedFields(dmmfModelName: string): ComputedFieldsMap | undefined {\n return this.computedFieldsCache.getOrCreate(dmmfModelName, () => {\n return getComputedFields(this.previous?.getAllComputedFields(dmmfModelName), this.extension, dmmfModelName)\n })\n }\n\n getAllClientExtensions(): ClientArg | undefined {\n return this.clientExtensions.get()\n }\n\n getAllModelExtensions(dmmfModelName: string): ModelArg | undefined {\n return this.modelExtensionsCache.getOrCreate(dmmfModelName, () => {\n const jsModelName = dmmfToJSModelName(dmmfModelName)\n if (!this.extension.model || !(this.extension.model[jsModelName] || this.extension.model.$allModels)) {\n return this.previous?.getAllModelExtensions(dmmfModelName)\n }\n\n return {\n ...this.previous?.getAllModelExtensions(dmmfModelName),\n ...this.extension.model.$allModels,\n ...this.extension.model[jsModelName],\n }\n })\n }\n\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n getAllQueryCallbacks(jsModelName: string | '$none', operation: string) {\n return this.queryCallbacksCache.getOrCreate(`${jsModelName}:${operation}`, () => {\n const prevCbs = this.previous?.getAllQueryCallbacks(jsModelName, operation) ?? []\n const newCbs: QueryOptionsCb[] = []\n const query = this.extension.query\n\n if (!query || !(query[jsModelName] || query['$allModels'] || query[operation] || query['$allOperations'])) {\n return prevCbs\n }\n\n if (query[jsModelName] !== undefined) {\n if (query[jsModelName][operation] !== undefined) {\n newCbs.push(query[jsModelName][operation])\n }\n\n // when the model-bound extension has a wildcard for the operation\n if (query[jsModelName]['$allOperations'] !== undefined) {\n newCbs.push(query[jsModelName]['$allOperations'])\n }\n }\n\n // when the extension isn't model-bound, apply it to all models\n // '$none' is a special case for top-level operations without model\n if (jsModelName !== '$none' && query['$allModels'] !== undefined) {\n if (query['$allModels'][operation] !== undefined) {\n newCbs.push(query['$allModels'][operation])\n }\n\n // when the non-model-bound extension has a wildcard for the operation\n if (query['$allModels']['$allOperations'] !== undefined) {\n newCbs.push(query['$allModels']['$allOperations'])\n }\n }\n\n // when the extension is not bound to a model & is a top-level operation\n if (query[operation] !== undefined) {\n newCbs.push(query[operation] as QueryOptionsCb)\n }\n\n // when the extension is not bound to a model & is any top-level operation\n if (query['$allOperations'] !== undefined) {\n newCbs.push(query['$allOperations'] as QueryOptionsCb)\n }\n\n return prevCbs.concat(newCbs)\n })\n }\n\n getAllBatchQueryCallbacks() {\n return this.batchCallbacks.get()\n }\n}\n\n/**\n * Class that holds the list of all extensions, applied to particular instance,\n * as well as resolved versions of the components that need to apply on\n * different levels. Main idea of this class: avoid re-resolving as much of the\n * stuff as possible when new extensions are added while also delaying the\n * resolve until the point it is actually needed. For example, computed fields\n * of the model won't be resolved unless the model is actually queried. Neither\n * adding extensions with `client` component only cause other components to\n * recompute.\n */\nexport class MergedExtensionsList {\n private constructor(private head?: MergedExtensionsListNode) {}\n\n static empty() {\n return new MergedExtensionsList()\n }\n\n static single(extension: ExtensionArgs) {\n return new MergedExtensionsList(new MergedExtensionsListNode(extension))\n }\n\n isEmpty(): boolean {\n return this.head === undefined\n }\n\n append(extension: ExtensionArgs) {\n return new MergedExtensionsList(new MergedExtensionsListNode(extension, this.head))\n }\n\n getAllComputedFields(dmmfModelName: string): ComputedFieldsMap | undefined {\n return this.head?.getAllComputedFields(dmmfModelName)\n }\n\n getAllClientExtensions() {\n return this.head?.getAllClientExtensions()\n }\n\n getAllModelExtensions(dmmfModelName: string) {\n return this.head?.getAllModelExtensions(dmmfModelName)\n }\n\n getAllQueryCallbacks(jsModelName: string, operation: string) {\n return this.head?.getAllQueryCallbacks(jsModelName, operation) ?? []\n }\n\n getAllBatchQueryCallbacks() {\n return this.head?.getAllBatchQueryCallbacks() ?? []\n }\n}\n", "import { Param } from '../types/exported/Param'\n\nexport class ParamImpl<Type, Name extends string> implements Param<Type, Name> {\n constructor(public readonly name: Name) {}\n}\n\nexport function isParam(value: unknown): value is Param<unknown, string> {\n return value instanceof ParamImpl\n}\n\nexport function createParam(name: string): Param<unknown, string> {\n return new ParamImpl(name)\n}\n", "// private symbol that prevents direct construction of a class\nconst secret = Symbol()\n\nexport class Skip {\n constructor(param?: symbol) {\n if (param !== secret) {\n throw new Error(`Skip instance can not be constructed directly`)\n }\n }\n\n ifUndefined<T>(value: T | undefined): T | Skip {\n if (value === undefined) {\n return skip\n }\n return value\n }\n}\n\nexport const skip = new Skip(secret)\n\nexport function isSkip(value: unknown): value is Skip {\n return value instanceof Skip\n}\n", "import { BaseDMMF, lazyProperty, RuntimeDataModel } from '@prisma/client-common'\n\nexport function defineDmmfProperty(target: object, runtimeDataModel: RuntimeDataModel) {\n const dmmfLazy = lazyProperty(() => runtimeDataModelToBaseDmmf(runtimeDataModel))\n\n Object.defineProperty(target, 'dmmf', {\n get: () => dmmfLazy.get(),\n })\n}\n\nfunction runtimeDataModelToBaseDmmf(runtimeDataModel: RuntimeDataModel): BaseDMMF {\n if (TARGET_BUILD_TYPE === 'wasm-compiler-edge') {\n throw new Error('Prisma.dmmf is not available when running in edge runtimes.')\n }\n\n return {\n datamodel: {\n models: buildDMMFList(runtimeDataModel.models),\n enums: buildDMMFList(runtimeDataModel.enums),\n types: buildDMMFList(runtimeDataModel.types),\n },\n }\n}\n\nfunction buildDMMFList<T>(map: Record<string, T>): Array<T & { name: string }> {\n return Object.entries(map).map(([name, props]) => ({ name, ...props }))\n}\n", "type TypedSqlInternal = {\n sql: string\n values: readonly unknown[]\n}\n\nconst internals = new WeakMap<TypedSql<any, any>, TypedSqlInternal>()\nconst TypedSqlMarker = '$$PrismaTypedSql'\n\nexport declare const PrivateResultType: unique symbol\n\nexport class TypedSql<Values extends readonly unknown[], Result> {\n declare [PrivateResultType]: Result\n\n constructor(sql: string, values: Values) {\n internals.set(this, {\n sql,\n values,\n })\n\n Object.defineProperty(this, TypedSqlMarker, { value: TypedSqlMarker })\n }\n\n get sql(): string {\n return internals.get(this)!.sql\n }\n\n get values(): Values {\n return internals.get(this)!.values as Values\n }\n}\n\nexport type UnknownTypedSql = TypedSql<unknown[], unknown>\n\nexport function makeTypedQueryFactory(sql: string) {\n return (...values) => new TypedSql(sql, values)\n}\n\n// used so we could detect typed sql instances, created by different instance of runtime\n// or after hmr trigger\nexport function isTypedSql(value: unknown): value is UnknownTypedSql {\n return value != null && value[TypedSqlMarker] === TypedSqlMarker\n}\n", "import type { Context } from '@opentelemetry/api'\nimport { GetPrismaClientConfig, RuntimeDataModel } from '@prisma/client-common'\nimport { RawValue, Sql } from '@prisma/client-runtime-utils'\nimport { clearLogs, Debug } from '@prisma/debug'\nimport type { SqlDriverAdapterFactory } from '@prisma/driver-adapter-utils'\nimport type { ExtendedSpanOptions, TracingHelper } from '@prisma/instrumentation-contract'\nimport { logger } from '@prisma/internals'\nimport type { SqlCommenterPlugin } from '@prisma/sqlcommenter'\nimport { AsyncResource } from 'async_hooks'\nimport { EventEmitter } from 'events'\n\nimport { PrismaClientInitializationError, PrismaClientValidationError } from '.'\nimport { addProperty, createCompositeProxy, removeProperties } from './core/compositeProxy'\nimport { BatchTransactionOptions, Engine, EngineConfig, Options } from './core/engines'\nimport { AccelerateEngineConfig, AccelerateExtensionFetchDecorator } from './core/engines/common/Engine'\nimport { EngineEvent, LogEmitter } from './core/engines/common/types/Events'\nimport type * as Transaction from './core/engines/common/types/Transaction'\nimport { prettyPrintArguments } from './core/errorRendering/prettyPrintArguments'\nimport { $extends } from './core/extensions/$extends'\nimport { applyAllResultExtensions } from './core/extensions/applyAllResultExtensions'\nimport { applyQueryExtensions } from './core/extensions/applyQueryExtensions'\nimport { MergedExtensionsList } from './core/extensions/MergedExtensionsList'\nimport { getEngineInstance } from './core/init/getEngineInstance'\nimport { GlobalOmitOptions, serializeJsonQuery } from './core/jsonProtocol/serializeJsonQuery'\nimport {\n applyModelsAndClientExtensions,\n unApplyModelsAndClientExtensions,\n} from './core/model/applyModelsAndClientExtensions'\nimport { rawCommandArgsMapper } from './core/raw-query/rawCommandArgsMapper'\nimport {\n checkAlter,\n rawQueryArgsMapper,\n sqlMiddlewareArgsMapper,\n templateStringMiddlewareArgsMapper,\n} from './core/raw-query/rawQueryArgsMapper'\nimport { createPrismaPromiseFactory } from './core/request/createPrismaPromise'\nimport {\n PrismaPromise,\n PrismaPromiseInteractiveTransaction,\n PrismaPromiseTransaction,\n} from './core/request/PrismaPromise'\nimport { UserArgs } from './core/request/UserArgs'\nimport { getTracingHelper } from './core/tracing/TracingHelper'\nimport { getLockCountPromise } from './core/transaction/utils/createLockCountPromise'\nimport { itxClientDenyList } from './core/types/exported/itxClientDenyList'\nimport { JsInputValue } from './core/types/exported/JsApi'\nimport { RawQueryArgs } from './core/types/exported/RawQueryArgs'\nimport { UnknownTypedSql } from './core/types/exported/TypedSql'\nimport { getLogLevel } from './getLogLevel'\nimport type { QueryMiddlewareParams } from './QueryMiddlewareParams'\nimport { RequestHandler } from './RequestHandler'\nimport { CallSite, getCallSite } from './utils/CallSite'\nimport { clientVersion } from './utils/clientVersion'\nimport { validatePrismaClientOptions } from './utils/validatePrismaClientOptions'\nimport { waitForBatch } from './utils/waitForBatch'\n\nconst debug = Debug('prisma:client')\n\ndeclare global {\n // eslint-disable-next-line no-var\n var NODE_CLIENT: true\n const TARGET_BUILD_TYPE: 'wasm-compiler-edge' | 'client'\n}\n\n// used by esbuild for tree-shaking\ntypeof globalThis === 'object' ? (globalThis.NODE_CLIENT = true) : 0\n\nexport type ErrorFormat = 'pretty' | 'colorless' | 'minimal'\n\n/**\n * Since Prisma 7, a PrismaClient needs either an adapter or an accelerateUrl.\n * The two options are mutually exclusive.\n */\ntype PrismaClientMutuallyExclusiveOptions =\n | {\n /**\n * Instance of a Driver Adapter, e.g., like one provided by `@prisma/adapter-pg`.\n */\n adapter: SqlDriverAdapterFactory\n accelerateUrl?: never\n }\n | {\n /**\n * Prisma Accelerate URL allowing the client to connect through Accelerate instead of a direct database.\n */\n accelerateUrl: string\n adapter?: never\n }\n\nexport type PrismaClientOptions = PrismaClientMutuallyExclusiveOptions & {\n /**\n * @default \"colorless\"\n */\n errorFormat?: ErrorFormat\n\n /**\n * The default values for Transaction options\n * maxWait ?= 2000\n * timeout ?= 5000\n */\n transactionOptions?: Transaction.Options\n\n /**\n * @example\n * \\`\\`\\`\n * // Defaults to stdout\n * log: ['query', 'info', 'warn']\n *\n * // Emit as events\n * log: [\n * { emit: 'stdout', level: 'query' },\n * { emit: 'stdout', level: 'info' },\n * { emit: 'stdout', level: 'warn' }\n * ]\n * \\`\\`\\`\n * Read more in our [docs](https://pris.ly/d/logging).\n */\n log?: Array<LogLevel | LogDefinition>\n\n omit?: GlobalOmitOptions\n\n /**\n * SQL commenter plugins that add metadata to SQL queries as comments.\n * Comments follow the sqlcommenter format: https://google.github.io/sqlcommenter/\n *\n * @example\n * ```ts\n * new PrismaClient({\n * adapter: new PrismaPg({ connectionString }),\n * comments: [\n * traceContext(),\n * queryInsights(),\n * ],\n * })\n * ```\n */\n comments?: SqlCommenterPlugin[]\n\n /**\n * @internal\n * You probably don't want to use this. \\`__internal\\` is used by internal tooling.\n */\n __internal?: {\n debug?: boolean\n /** This can be used for testing purposes */\n configOverride?: (config: GetPrismaClientConfig) => GetPrismaClientConfig\n }\n}\n\nexport type Unpacker = (data: any) => any\n\nexport type InternalRequestParams = {\n /**\n * The original client method being called.\n * Even though the rootField / operation can be changed,\n * this method stays as it is, as it's what the user's\n * code looks like\n */\n clientMethod: string // TODO what is this\n /**\n * Name of js model that triggered the request. Might be used\n * for warnings or error messages\n */\n jsModelName?: string\n // Extra headers for data proxy.\n callsite?: CallSite\n transaction?: PrismaPromiseTransaction\n unpacker?: Unpacker // TODO what is this\n otelParentCtx?: Context\n /** Used to \"desugar\" a user input into an \"expanded\" one */\n argsMapper?: (args?: UserArgs) => UserArgs\n\n /** Used to convert args for middleware and back */\n middlewareArgsMapper?: MiddlewareArgsMapper<unknown, unknown>\n /** Used for Accelerate client extension via Data Proxy */\n customDataProxyFetch?: AccelerateExtensionFetchDecorator\n} & Omit<QueryMiddlewareParams, 'runInTransaction'>\n\nexport type MiddlewareArgsMapper<RequestArgs, MiddlewareArgs> = {\n requestArgsToMiddlewareArgs(requestArgs: RequestArgs): MiddlewareArgs\n middlewareArgsToRequestArgs(middlewareArgs: MiddlewareArgs): RequestArgs\n}\n\nconst noopMiddlewareArgsMapper: MiddlewareArgsMapper<unknown, unknown> = {\n requestArgsToMiddlewareArgs: (param) => param,\n middlewareArgsToRequestArgs: (param) => param,\n}\n\n/* Types for Logging */\nexport type LogLevel = 'info' | 'query' | 'warn' | 'error'\nexport type LogDefinition = {\n level: LogLevel\n emit: 'stdout' | 'event'\n}\n\nexport type QueryEvent = {\n timestamp: Date\n query: string\n params: string\n duration: number\n target: string\n}\n\nexport type LogEvent = {\n timestamp: Date\n message: string\n target: string\n}\n/* End Types for Logging */\n\ntype ExtendedEventType = LogLevel | 'beforeExit'\ntype EventCallback<E extends ExtendedEventType> = [E] extends ['beforeExit']\n ? () => Promise<void>\n : [E] extends [LogLevel]\n ? (event: EngineEvent<E>) => void\n : never\n\nconst TX_ID = Symbol.for('prisma.client.transaction.id')\n\nconst BatchTxIdCounter = {\n id: 0,\n nextId() {\n return ++this.id\n },\n}\n\nexport type Client =\n ReturnType<typeof getPrismaClient> extends new (optionsArg: PrismaClientOptions) => infer T ? T : never\n\nexport function getPrismaClient(config: GetPrismaClientConfig) {\n class PrismaClient {\n _originalClient = this\n _runtimeDataModel: RuntimeDataModel\n _requestHandler: RequestHandler\n _connectionPromise?: Promise<any>\n _disconnectionPromise?: Promise<any>\n _engineConfig: EngineConfig\n _accelerateEngineConfig: AccelerateEngineConfig\n _clientVersion: string\n _errorFormat: ErrorFormat\n _tracingHelper: TracingHelper\n _previewFeatures: string[]\n _activeProvider: string\n _globalOmit?: GlobalOmitOptions\n _extensions: MergedExtensionsList\n /**\n * @remarks This is used internally by Policy, do not rename or remove\n */\n _engine: Engine\n /**\n * A fully constructed/applied Client that references the parent\n * PrismaClient. This is used for Client extensions only.\n */\n _appliedParent: PrismaClient\n _createPrismaPromise = createPrismaPromiseFactory()\n\n constructor(optionsArg: PrismaClientOptions) {\n if (!optionsArg) {\n throw new PrismaClientInitializationError(\n `\\\n\\`PrismaClient\\` needs to be constructed with a non-empty, valid \\`PrismaClientOptions\\`:\n\n\\`\\`\\`\nnew PrismaClient({\n ...\n})\n\\`\\`\\`\n\nor\n\n\\`\\`\\`\nconstructor() {\n super({ ... });\n}\n\\`\\`\\`\n `,\n clientVersion,\n )\n }\n config = optionsArg.__internal?.configOverride?.(config) ?? config\n validatePrismaClientOptions(optionsArg, config)\n\n // prevents unhandled error events when users do not explicitly listen to them\n const logEmitter = new EventEmitter().on('error', () => {}) as LogEmitter\n\n this._extensions = MergedExtensionsList.empty()\n this._previewFeatures = config.previewFeatures\n this._clientVersion = config.clientVersion ?? clientVersion\n this._activeProvider = config.activeProvider\n this._globalOmit = optionsArg?.omit\n this._tracingHelper = getTracingHelper()\n\n /**\n * Initialise and validate the Driver Adapter, if provided.\n */\n\n let adapter: SqlDriverAdapterFactory | undefined\n if (optionsArg.adapter) {\n adapter = optionsArg.adapter\n\n // Note:\n // - `getConfig(..).datasources[0].provider` can be `postgresql`, `postgres`, `mysql`, or other known providers\n // - `getConfig(..).datasources[0].activeProvider`, stored in `config.activeProvider`, can be `postgresql`, `mysql`, or other known providers\n // - `adapter.provider` can be `postgres`, `mysql`, or `sqlite`, and changing this requires changes to Rust as well,\n // see https://github.com/prisma/prisma-engines/blob/d116c37d7d27aee74fdd840fc85ab2b45407e5ce/query-engine/driver-adapters/src/types.rs#L22-L23.\n //\n // TODO: Normalize these provider names once and for all in Prisma 6.\n const expectedDriverAdapterProvider =\n config.activeProvider === 'postgresql'\n ? 'postgres'\n : // CockroachDB is only accessible through Postgres driver adapters\n config.activeProvider === 'cockroachdb'\n ? 'postgres'\n : config.activeProvider\n\n if (adapter.provider !== expectedDriverAdapterProvider) {\n throw new PrismaClientInitializationError(\n `The Driver Adapter \\`${adapter.adapterName}\\`, based on \\`${adapter.provider}\\`, is not compatible with the provider \\`${expectedDriverAdapterProvider}\\` specified in the Prisma schema.`,\n this._clientVersion,\n )\n }\n }\n\n try {\n const options: PrismaClientOptions = optionsArg ?? {}\n const internal = options.__internal ?? {}\n\n const useDebug = internal.debug === true\n if (useDebug) {\n Debug.enable('prisma:client')\n }\n\n if (options.errorFormat) {\n this._errorFormat = options.errorFormat\n } else if (process.env.NODE_ENV === 'production') {\n this._errorFormat = 'minimal'\n } else if (process.env.NO_COLOR) {\n this._errorFormat = 'colorless'\n } else {\n this._errorFormat = 'colorless' // default errorFormat\n }\n\n this._runtimeDataModel = config.runtimeDataModel\n\n this._engineConfig = {\n enableDebugLogs: useDebug,\n logLevel: options.log && (getLogLevel(options.log) as any), // TODO\n logQueries:\n options.log &&\n Boolean(\n typeof options.log === 'string'\n ? options.log === 'query'\n : options.log.find((o) => (typeof o === 'string' ? o === 'query' : o.level === 'query')),\n ),\n compilerWasm: config.compilerWasm,\n clientVersion: config.clientVersion,\n previewFeatures: this._previewFeatures,\n activeProvider: config.activeProvider,\n inlineSchema: config.inlineSchema,\n tracingHelper: this._tracingHelper,\n transactionOptions: {\n maxWait: options.transactionOptions?.maxWait ?? 2000,\n timeout: options.transactionOptions?.timeout ?? 5000,\n isolationLevel: options.transactionOptions?.isolationLevel,\n },\n logEmitter,\n adapter,\n accelerateUrl: options.accelerateUrl,\n sqlCommenters: options.comments,\n parameterizationSchema: config.parameterizationSchema,\n runtimeDataModel: config.runtimeDataModel,\n }\n\n // Used in <https://github.com/prisma/prisma-extension-accelerate/blob/b6ffa853f038780f5ab2fc01bff584ca251f645b/src/extension.ts#L514>\n this._accelerateEngineConfig = Object.create(this._engineConfig)\n this._accelerateEngineConfig.accelerateUtils = {\n resolveDatasourceUrl: () => {\n if (options.accelerateUrl) {\n return options.accelerateUrl\n }\n throw new PrismaClientInitializationError(\n `\\\n\\`accelerateUrl\\` is required when using \\`@prisma/extension-accelerate\\`:\n\nnew PrismaClient({\n accelerateUrl: \"prisma://...\",\n}).$extends(withAccelerate())\n`,\n config.clientVersion,\n )\n },\n }\n\n debug('clientVersion', config.clientVersion)\n\n this._engine = getEngineInstance(this._engineConfig)\n this._requestHandler = new RequestHandler(this, logEmitter)\n\n if (options.log) {\n for (const log of options.log) {\n const level = typeof log === 'string' ? log : log.emit === 'stdout' ? log.level : null\n if (level) {\n this.$on(level, (event) => {\n logger.log(`${logger.tags[level] ?? ''}`, (event as LogEvent).message || (event as QueryEvent).query)\n })\n }\n }\n }\n } catch (e: any) {\n e.clientVersion = this._clientVersion\n throw e\n }\n\n // the first client has no parent so it is its own parent client\n // this is used for extensions to reference their parent client\n return (this._appliedParent = applyModelsAndClientExtensions(this))\n // this applied client is also a custom constructor return value\n }\n\n get [Symbol.toStringTag]() {\n return 'PrismaClient'\n }\n\n $on<E extends ExtendedEventType>(eventType: E, callback: EventCallback<E>): PrismaClient {\n if (eventType === 'beforeExit') {\n this._engine.onBeforeExit(callback as EventCallback<'beforeExit'>)\n } else if (eventType) {\n this._engineConfig.logEmitter.on(eventType, callback as EventCallback<LogLevel>)\n }\n return this\n }\n\n $connect() {\n try {\n return this._engine.start()\n } catch (e: any) {\n e.clientVersion = this._clientVersion\n throw e\n }\n }\n\n /**\n * Disconnect from the database\n */\n async $disconnect() {\n try {\n await this._engine.stop()\n } catch (e: any) {\n e.clientVersion = this._clientVersion\n throw e\n } finally {\n // Debug module keeps a list of last 100 logs regardless of environment\n // variables. This can cause a memory leak. It's especially bad in jest\n // environment where keeping an error in this list prevents jest sandbox\n // from being GCed. Clearing logs on disconnect helps to avoid that\n clearLogs()\n }\n }\n\n /**\n * Executes a raw query and always returns a number\n */\n $executeRawInternal(\n transaction: PrismaPromiseTransaction | undefined,\n clientMethod: string,\n args: RawQueryArgs,\n middlewareArgsMapper?: MiddlewareArgsMapper<unknown, unknown>,\n ): Promise<number> {\n const activeProvider = this._activeProvider\n\n return this._request({\n action: 'executeRaw',\n args,\n transaction,\n clientMethod,\n argsMapper: rawQueryArgsMapper({ clientMethod, activeProvider }),\n callsite: getCallSite(this._errorFormat),\n dataPath: [],\n middlewareArgsMapper,\n })\n }\n\n /**\n * Executes a raw query provided through a safe tag function\n * @see https://github.com/prisma/prisma/issues/7142\n *\n * @param query\n * @param values\n * @returns\n */\n $executeRaw(query: TemplateStringsArray | Sql, ...values: any[]) {\n return this._createPrismaPromise((transaction) => {\n if ((query as TemplateStringsArray).raw !== undefined || (query as Sql).sql !== undefined) {\n const [sql, argsMapper] = toSql(query, values)\n checkAlter(\n this._activeProvider,\n sql.text,\n sql.values,\n Array.isArray(query) ? 'prisma.$executeRaw`<SQL>`' : 'prisma.$executeRaw(sql`<SQL>`)',\n )\n return this.$executeRawInternal(transaction, '$executeRaw', sql, argsMapper)\n }\n\n throw new PrismaClientValidationError(\n `\\`$executeRaw\\` is a tag function, please use it like the following:\n\\`\\`\\`\nconst result = await prisma.$executeRaw\\`UPDATE User SET cool = \\${true} WHERE email = \\${'user@email.com'};\\`\n\\`\\`\\`\n\nOr read our docs at https://www.prisma.io/docs/concepts/components/prisma-client/raw-database-access#executeraw\n`,\n { clientVersion: this._clientVersion },\n )\n })\n }\n\n /**\n * Unsafe counterpart of `$executeRaw` that is susceptible to SQL injections\n * @see https://github.com/prisma/prisma/issues/7142\n *\n * @param query\n * @param values\n * @returns\n */\n $executeRawUnsafe(query: string, ...values: RawValue[]) {\n return this._createPrismaPromise((transaction) => {\n checkAlter(this._activeProvider, query, values, 'prisma.$executeRawUnsafe(<SQL>, [...values])')\n return this.$executeRawInternal(transaction, '$executeRawUnsafe', [query, ...values])\n })\n }\n\n /**\n * Executes a raw command only for MongoDB\n *\n * @param command\n * @returns\n */\n $runCommandRaw(command: Record<string, JsInputValue>) {\n if (config.activeProvider !== 'mongodb') {\n throw new PrismaClientValidationError(\n `The ${config.activeProvider} provider does not support $runCommandRaw. Use the mongodb provider.`,\n { clientVersion: this._clientVersion },\n )\n }\n\n return this._createPrismaPromise((transaction) => {\n return this._request({\n args: command,\n clientMethod: '$runCommandRaw',\n dataPath: [],\n action: 'runCommandRaw',\n argsMapper: rawCommandArgsMapper,\n callsite: getCallSite(this._errorFormat),\n transaction: transaction,\n })\n })\n }\n\n /**\n * Executes a raw query and returns selected data\n */\n async $queryRawInternal(\n transaction: PrismaPromiseTransaction | undefined,\n clientMethod: string,\n args: RawQueryArgs,\n middlewareArgsMapper?: MiddlewareArgsMapper<unknown, unknown>,\n ) {\n const activeProvider = this._activeProvider\n\n return this._request({\n action: 'queryRaw',\n args,\n transaction,\n clientMethod,\n argsMapper: rawQueryArgsMapper({ clientMethod, activeProvider }),\n callsite: getCallSite(this._errorFormat),\n dataPath: [],\n middlewareArgsMapper,\n })\n }\n\n /**\n * Executes a raw query provided through a safe tag function\n * @see https://github.com/prisma/prisma/issues/7142\n *\n * @param query\n * @param values\n * @returns\n */\n $queryRaw(query: TemplateStringsArray | Sql, ...values: any[]) {\n return this._createPrismaPromise((transaction) => {\n if ((query as TemplateStringsArray).raw !== undefined || (query as Sql).sql !== undefined) {\n return this.$queryRawInternal(transaction, '$queryRaw', ...toSql(query, values))\n }\n\n throw new PrismaClientValidationError(\n `\\`$queryRaw\\` is a tag function, please use it like the following:\n\\`\\`\\`\nconst result = await prisma.$queryRaw\\`SELECT * FROM User WHERE id = \\${1} OR email = \\${'user@email.com'};\\`\n\\`\\`\\`\n\nOr read our docs at https://www.prisma.io/docs/concepts/components/prisma-client/raw-database-access#queryraw\n`,\n { clientVersion: this._clientVersion },\n )\n })\n }\n\n /**\n * Counterpart to $queryRaw, that returns strongly typed results\n * @param typedSql\n */\n $queryRawTyped(typedSql: UnknownTypedSql) {\n return this._createPrismaPromise((transaction) => {\n if (!this._hasPreviewFlag('typedSql')) {\n throw new PrismaClientValidationError(\n '`typedSql` preview feature must be enabled in order to access $queryRawTyped API',\n { clientVersion: this._clientVersion },\n )\n }\n return this.$queryRawInternal(transaction, '$queryRawTyped', typedSql)\n })\n }\n\n /**\n * Unsafe counterpart of `$queryRaw` that is susceptible to SQL injections\n * @see https://github.com/prisma/prisma/issues/7142\n *\n * @param query\n * @param values\n * @returns\n */\n $queryRawUnsafe(query: string, ...values: RawValue[]) {\n return this._createPrismaPromise((transaction) => {\n return this.$queryRawInternal(transaction, '$queryRawUnsafe', [query, ...values])\n })\n }\n\n /**\n * Execute a batch of requests in a transaction\n * @param requests\n * @param options\n */\n _transactionWithArray({\n promises,\n options,\n }: {\n promises: Array<PrismaPromise<any>>\n options?: BatchTransactionOptions\n }): Promise<any> {\n const id = BatchTxIdCounter.nextId()\n const lock = getLockCountPromise(promises.length)\n\n const requests = promises.map((request, index) => {\n if (request?.[Symbol.toStringTag] !== 'PrismaPromise') {\n throw new Error(\n `All elements of the array need to be Prisma Client promises. Hint: Please make sure you are not awaiting the Prisma client calls you intended to pass in the $transaction function.`,\n )\n }\n\n const isolationLevel = options?.isolationLevel ?? this._engineConfig.transactionOptions.isolationLevel\n const transaction = { kind: 'batch', id, index, isolationLevel, lock } as const\n return request.requestTransaction?.(transaction) ?? request\n })\n\n return waitForBatch(requests)\n }\n\n /**\n * Perform a long-running transaction\n * @param callback\n * @param options\n * @returns\n */\n async _transactionWithCallback({\n callback,\n options,\n }: {\n callback: (client: Client) => Promise<unknown>\n options?: Options\n }) {\n const headers = { traceparent: this._tracingHelper.getTraceParent() }\n\n const optionsWithDefaults: Options = {\n maxWait: options?.maxWait ?? this._engineConfig.transactionOptions.maxWait,\n timeout: options?.timeout ?? this._engineConfig.transactionOptions.timeout,\n isolationLevel: options?.isolationLevel ?? this._engineConfig.transactionOptions.isolationLevel,\n }\n const info = await this._engine.transaction('start', headers, optionsWithDefaults)\n\n let result: unknown\n try {\n // execute user logic with a proxied the client\n const transaction = { kind: 'itx', ...info } as const\n\n result = await callback(this._createItxClient(transaction))\n\n // it went well, then we commit the transaction\n await this._engine.transaction('commit', headers, info)\n } catch (e: any) {\n // it went bad, then we rollback the transaction\n await this._engine.transaction('rollback', headers, info).catch(() => {})\n\n throw e // silent rollback, throw original error\n }\n\n return result\n }\n\n _createItxClient(transaction: PrismaPromiseInteractiveTransaction): Client {\n return createCompositeProxy(\n applyModelsAndClientExtensions(\n createCompositeProxy(unApplyModelsAndClientExtensions(this), [\n addProperty('_appliedParent', () => this._appliedParent._createItxClient(transaction)),\n addProperty('_createPrismaPromise', () => createPrismaPromiseFactory(transaction)),\n addProperty(TX_ID, () => transaction.id),\n ]),\n ),\n [removeProperties(itxClientDenyList)],\n )\n }\n\n /**\n * Execute queries within a transaction\n * @param input a callback or a query list\n * @param options to set timeouts (callback)\n * @returns\n */\n $transaction(input: any, options?: any) {\n let callback: () => Promise<any>\n\n // iTx - Interactive transaction\n if (typeof input === 'function') {\n if (this._engineConfig.adapter?.adapterName === '@prisma/adapter-d1') {\n callback = () => {\n throw new Error(\n 'Cloudflare D1 does not support interactive transactions. We recommend you to refactor your queries with that limitation in mind, and use batch transactions with `prisma.$transactions([])` where applicable.',\n )\n }\n } else {\n callback = () => this._transactionWithCallback({ callback: input, options })\n }\n } else {\n // Batch transaction\n callback = () => this._transactionWithArray({ promises: input, options })\n }\n\n const spanOptions = {\n name: 'transaction',\n attributes: { method: '$transaction' },\n }\n\n return this._tracingHelper.runInChildSpan(spanOptions, callback)\n }\n\n /**\n * Runs the middlewares over params before executing a request\n * @param internalParams\n * @returns\n */\n _request(internalParams: InternalRequestParams): Promise<any> {\n // this is the otel context that is active at the callsite\n internalParams.otelParentCtx = this._tracingHelper.getActiveContext()\n const middlewareArgsMapper = internalParams.middlewareArgsMapper ?? noopMiddlewareArgsMapper\n\n // make sure that we don't leak extra properties to users\n const params: QueryMiddlewareParams = {\n args: middlewareArgsMapper.requestArgsToMiddlewareArgs(internalParams.args),\n dataPath: internalParams.dataPath,\n runInTransaction: Boolean(internalParams.transaction),\n action: internalParams.action,\n model: internalParams.model,\n }\n\n // span options for opentelemetry instrumentation\n const spanOptions = {\n operation: {\n name: 'operation',\n attributes: {\n method: params.action,\n model: params.model,\n name: params.model ? `${params.model}.${params.action}` : params.action,\n },\n } as ExtendedSpanOptions,\n }\n\n // prepare recursive fn that will pipe params through middlewares\n const consumer = async (changedMiddlewareParams: QueryMiddlewareParams) => {\n // we proceed with request execution\n // before we send the execution request, we use the changed params\n const { runInTransaction, args, ...changedRequestParams } = changedMiddlewareParams\n const requestParams = {\n ...internalParams,\n ...changedRequestParams,\n }\n\n if (args) {\n requestParams.args = middlewareArgsMapper.middlewareArgsToRequestArgs(args)\n }\n\n // if middleware switched off `runInTransaction`, unset `transaction`\n // property on request as well so it will be executed outside of the tx\n if (internalParams.transaction !== undefined && runInTransaction === false) {\n delete requestParams.transaction // client extensions check for this\n }\n\n const result = await applyQueryExtensions(this, requestParams) // also executes the query\n if (!requestParams.model) {\n return result\n }\n return applyAllResultExtensions({\n result,\n modelName: requestParams.model,\n args: requestParams.args,\n extensions: this._extensions,\n runtimeDataModel: this._runtimeDataModel,\n globalOmit: this._globalOmit,\n })\n }\n\n return this._tracingHelper.runInChildSpan(spanOptions.operation, () => {\n if (NODE_CLIENT) {\n // https://github.com/prisma/prisma/issues/3148 not for edge client\n const asyncRes = new AsyncResource('prisma-client-request')\n return asyncRes.runInAsyncScope(() => consumer(params))\n }\n\n return consumer(params)\n })\n }\n\n async _executeRequest({\n args,\n clientMethod,\n dataPath,\n callsite,\n action,\n model,\n argsMapper,\n transaction,\n unpacker,\n otelParentCtx,\n customDataProxyFetch,\n }: InternalRequestParams) {\n try {\n // execute argument transformation before execution\n args = argsMapper ? argsMapper(args) : args\n\n const spanOptions: ExtendedSpanOptions = {\n name: 'serialize',\n }\n\n const message = this._tracingHelper.runInChildSpan(spanOptions, () =>\n serializeJsonQuery({\n modelName: model,\n runtimeDataModel: this._runtimeDataModel,\n action,\n args,\n clientMethod,\n callsite,\n extensions: this._extensions,\n errorFormat: this._errorFormat,\n clientVersion: this._clientVersion,\n previewFeatures: this._previewFeatures,\n globalOmit: this._globalOmit,\n }),\n )\n\n // as prettyPrintArguments takes a bit of compute\n // we only want to do it, if debug is enabled for 'prisma-client'\n if (Debug.enabled('prisma:client')) {\n debug(`Prisma Client call:`)\n debug(`prisma.${clientMethod}(${prettyPrintArguments(args)})`)\n debug(`Generated request:`)\n debug(JSON.stringify(message, null, 2) + '\\n')\n }\n\n if (transaction?.kind === 'batch') {\n /** @see {@link getLockCountPromise} */\n await transaction.lock\n }\n\n return this._requestHandler.request({\n protocolQuery: message,\n modelName: model,\n action,\n clientMethod,\n dataPath,\n callsite,\n args,\n extensions: this._extensions,\n transaction,\n unpacker,\n otelParentCtx,\n otelChildCtx: this._tracingHelper.getActiveContext(),\n globalOmit: this._globalOmit,\n customDataProxyFetch,\n })\n } catch (e) {\n e.clientVersion = this._clientVersion\n throw e\n }\n }\n\n /**\n * Shortcut for checking a preview flag\n * @param feature preview flag\n * @returns\n */\n _hasPreviewFlag(feature: string) {\n return !!this._engineConfig.previewFeatures?.includes(feature)\n }\n\n $extends = $extends\n }\n\n return PrismaClient\n}\n\nfunction toSql(query: TemplateStringsArray | Sql, values: unknown[]): [Sql, MiddlewareArgsMapper<unknown, unknown>] {\n if (isTemplateStringArray(query)) {\n return [new Sql(query, values), templateStringMiddlewareArgsMapper]\n }\n\n return [query, sqlMiddlewareArgsMapper]\n}\n\nfunction isTemplateStringArray(value: unknown): value is TemplateStringsArray {\n return Array.isArray(value) && Array.isArray(value['raw'])\n}\n", "import type { CompositeProxyLayer } from './createCompositeProxy'\n\n/**\n * Composite proxy layer that forwards all reads\n * to provided object\n *\n * @param object\n * @returns\n */\nexport function addObjectProperties(object: object): CompositeProxyLayer {\n return {\n getKeys() {\n return Object.keys(object)\n },\n\n getPropertyValue(key) {\n return object[key]\n },\n }\n}\n", "import { CompositeProxyLayer } from './createCompositeProxy'\n\n/**\n * Composite proxy layer, that adds a single property to the target\n * @param key the name of the property\n * @param factory the function that returns the value of the property\n * @returns\n */\nexport function addProperty(key: string | symbol, factory: () => unknown): CompositeProxyLayer {\n return {\n getKeys() {\n return [key]\n },\n\n getPropertyValue() {\n return factory()\n },\n }\n}\n", "import { Cache } from '@prisma/client-common'\n\nimport { CompositeProxyLayer } from './createCompositeProxy'\n\n/**\n * Composite proxy layer that adds caching to another\n * layer.\n *\n * @param baseLayer\n * @returns\n */\nexport function cacheProperties<KeyType extends string | symbol>(\n baseLayer: CompositeProxyLayer<KeyType>,\n): CompositeProxyLayer<KeyType> {\n const cache = new Cache<KeyType, unknown>()\n return {\n getKeys() {\n return baseLayer.getKeys()\n },\n\n getPropertyValue(key) {\n return cache.getOrCreate(key, () => baseLayer.getPropertyValue(key))\n },\n\n getPropertyDescriptor(key) {\n return baseLayer.getPropertyDescriptor?.(key)\n },\n }\n}\n", "export const defaultPropertyDescriptor = {\n enumerable: true,\n configurable: true,\n writable: true,\n}\n\nexport function defaultProxyHandlers<T extends object>(ownKeys: (string | symbol)[]) {\n const _ownKeys = new Set(ownKeys)\n return {\n getPrototypeOf: () => Object.prototype,\n getOwnPropertyDescriptor: () => defaultPropertyDescriptor,\n has: (target: T, prop: string | symbol) => _ownKeys.has(prop),\n set: (target: T, prop: string | symbol, value: any) => {\n return _ownKeys.add(prop) && Reflect.set(target, prop, value)\n },\n ownKeys: () => [..._ownKeys],\n } as const\n}\n", "import { defaultPropertyDescriptor } from '../model/utils/defaultProxyHandlers'\n\nexport interface CompositeProxyLayer<KeyType extends string | symbol = string | symbol> {\n /**\n * Returns a list of keys, defined by a layer\n */\n getKeys(): ReadonlyArray<KeyType>\n\n /**\n * Returns a value for a property for a given key (one of the keys, returned\n * from `getKeys`)\n * @param key\n */\n getPropertyValue(key: KeyType): unknown\n\n /**\n * Gets a descriptor for given property. If not implemented or undefined is returned, { enumerable: true, writeable: true, configurable: true} is defaulted\n * is used\n * @param key\n */\n getPropertyDescriptor?(key: KeyType): PropertyDescriptor | undefined\n\n /**\n * Allows to override results for hasOwnProperty/in operator. If not implemented, returns true\n * @param key\n */\n has?(key: KeyType): boolean\n}\n\nconst customInspect = Symbol.for('nodejs.util.inspect.custom')\n\n/**\n * Creates a proxy from a set of layers.\n * Each layer is a building for a proxy (potentially, reusable) that\n * can add or override property on top of the target.\n * When multiple layers define the same property, last one wins\n *\n * @param target\n * @param layers\n * @returns\n */\nexport function createCompositeProxy<T extends object>(target: T, layers: CompositeProxyLayer[]): T {\n const keysToLayerMap = mapKeysToLayers(layers)\n const overwrittenKeys = new Set<string | symbol>()\n\n const proxy = new Proxy(target, {\n get(target, prop) {\n // explicit overwrites of a property have highest priority\n if (overwrittenKeys.has(prop)) {\n return target[prop]\n }\n\n // next, we see if property is defined in one of the layers\n const layer = keysToLayerMap.get(prop)\n if (layer) {\n return layer.getPropertyValue(prop)\n }\n\n // finally, we read a prop from target\n return target[prop]\n },\n\n has(target, prop) {\n if (overwrittenKeys.has(prop)) {\n return true\n }\n const layer = keysToLayerMap.get(prop)\n if (layer) {\n return layer.has?.(prop) ?? true\n }\n\n return Reflect.has(target, prop)\n },\n\n ownKeys(target) {\n const targetKeys = getExistingKeys(Reflect.ownKeys(target), keysToLayerMap)\n const layerKeys = getExistingKeys(Array.from(keysToLayerMap.keys()), keysToLayerMap)\n return [...new Set([...targetKeys, ...layerKeys, ...overwrittenKeys])]\n },\n\n set(target, prop, value) {\n const layer = keysToLayerMap.get(prop)\n if (layer?.getPropertyDescriptor?.(prop)?.writable === false) {\n return false\n }\n overwrittenKeys.add(prop)\n return Reflect.set(target, prop, value)\n },\n\n getOwnPropertyDescriptor(target, prop) {\n const original = Reflect.getOwnPropertyDescriptor(target, prop)\n if (original && !original.configurable) {\n // non-configurable properties can not change descriptors\n return original\n }\n\n const layer = keysToLayerMap.get(prop)\n if (layer) {\n if (layer.getPropertyDescriptor) {\n return {\n ...defaultPropertyDescriptor,\n ...layer?.getPropertyDescriptor(prop),\n }\n }\n return defaultPropertyDescriptor\n }\n\n return original\n },\n\n defineProperty(target, property, attributes) {\n overwrittenKeys.add(property)\n return Reflect.defineProperty(target, property, attributes)\n },\n\n getPrototypeOf: () => Object.prototype,\n })\n\n proxy[customInspect] = function () {\n // Default node.js console.log and util.inspect deliberately avoid triggering any proxy traps and log\n // original target. This is not we want for our usecases: we want console.log to output the result as if\n // the properties actually existed on the target. Using spread operator forces us to produce correct object\n const toLog = { ...this }\n delete toLog[customInspect]\n return toLog\n }\n return proxy\n}\n\nfunction mapKeysToLayers(layers: CompositeProxyLayer[]) {\n const keysToLayerMap = new Map<string | symbol, CompositeProxyLayer>()\n for (const layer of layers) {\n const keys = layer.getKeys()\n for (const key of keys) {\n keysToLayerMap.set(key, layer)\n }\n }\n return keysToLayerMap\n}\n\nfunction getExistingKeys(keys: Array<string | symbol>, keysToLayerMap: Map<string | symbol, CompositeProxyLayer>) {\n return keys.filter((key) => {\n const layer = keysToLayerMap.get(key)\n return layer?.has?.(key) ?? true\n })\n}\n", "import { CompositeProxyLayer } from './createCompositeProxy'\n\nexport function removeProperties(keys: ReadonlyArray<string | symbol>): CompositeProxyLayer {\n return {\n getKeys() {\n return keys\n },\n\n has() {\n return false\n },\n\n getPropertyValue() {\n return undefined\n },\n }\n}\n", "import { Writer } from '@prisma/ts-builders'\n\nimport { JsArgs } from '../types/exported/JsApi'\nimport { buildArgumentsRenderingTree } from './ArgumentsRenderingTree'\nimport { inactiveColors } from './base'\n\nexport function prettyPrintArguments(args?: JsArgs): string {\n if (args === undefined) {\n return ''\n }\n const tree = buildArgumentsRenderingTree(args)\n const writer = new Writer(0, { colors: inactiveColors })\n return writer.write(tree).toString()\n}\n", "var UNKNOWN_FUNCTION = '<unknown>';\n/**\n * This parses the different stack traces and puts them into one format\n * This borrows heavily from TraceKit (https://github.com/csnover/TraceKit)\n */\n\nfunction parse(stackString) {\n var lines = stackString.split('\\n');\n return lines.reduce(function (stack, line) {\n var parseResult = parseChrome(line) || parseWinjs(line) || parseGecko(line) || parseNode(line) || parseJSC(line);\n\n if (parseResult) {\n stack.push(parseResult);\n }\n\n return stack;\n }, []);\n}\nvar chromeRe = /^\\s*at (.*?) ?\\(((?:file|https?|blob|chrome-extension|native|eval|webpack|rsc|<anonymous>|\\/|[a-z]:\\\\|\\\\\\\\).*?)(?::(\\d+))?(?::(\\d+))?\\)?\\s*$/i;\nvar chromeEvalRe = /\\((\\S*)(?::(\\d+))(?::(\\d+))\\)/;\n\nfunction parseChrome(line) {\n var parts = chromeRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n var isNative = parts[2] && parts[2].indexOf('native') === 0; // start of line\n\n var isEval = parts[2] && parts[2].indexOf('eval') === 0; // start of line\n\n var submatch = chromeEvalRe.exec(parts[2]);\n\n if (isEval && submatch != null) {\n // throw out eval line/column and use top-most line/column number\n parts[2] = submatch[1]; // url\n\n parts[3] = submatch[2]; // line\n\n parts[4] = submatch[3]; // column\n }\n\n return {\n file: !isNative ? parts[2] : null,\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: isNative ? [parts[2]] : [],\n lineNumber: parts[3] ? +parts[3] : null,\n column: parts[4] ? +parts[4] : null\n };\n}\n\nvar winjsRe = /^\\s*at (?:((?:\\[object object\\])?.+) )?\\(?((?:file|ms-appx|https?|webpack|rsc|blob):.*?):(\\d+)(?::(\\d+))?\\)?\\s*$/i;\n\nfunction parseWinjs(line) {\n var parts = winjsRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n return {\n file: parts[2],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: [],\n lineNumber: +parts[3],\n column: parts[4] ? +parts[4] : null\n };\n}\n\nvar geckoRe = /^\\s*(.*?)(?:\\((.*?)\\))?(?:^|@)((?:file|https?|blob|chrome|webpack|rsc|resource|\\[native).*?|[^@]*bundle)(?::(\\d+))?(?::(\\d+))?\\s*$/i;\nvar geckoEvalRe = /(\\S+) line (\\d+)(?: > eval line \\d+)* > eval/i;\n\nfunction parseGecko(line) {\n var parts = geckoRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n var isEval = parts[3] && parts[3].indexOf(' > eval') > -1;\n var submatch = geckoEvalRe.exec(parts[3]);\n\n if (isEval && submatch != null) {\n // throw out eval line/column and use top-most line number\n parts[3] = submatch[1];\n parts[4] = submatch[2];\n parts[5] = null; // no column when eval\n }\n\n return {\n file: parts[3],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: parts[2] ? parts[2].split(',') : [],\n lineNumber: parts[4] ? +parts[4] : null,\n column: parts[5] ? +parts[5] : null\n };\n}\n\nvar javaScriptCoreRe = /^\\s*(?:([^@]*)(?:\\((.*?)\\))?@)?(\\S.*?):(\\d+)(?::(\\d+))?\\s*$/i;\n\nfunction parseJSC(line) {\n var parts = javaScriptCoreRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n return {\n file: parts[3],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: [],\n lineNumber: +parts[4],\n column: parts[5] ? +parts[5] : null\n };\n}\n\nvar nodeRe = /^\\s*at (?:((?:\\[object object\\])?[^\\\\/]+(?: \\[as \\S+\\])?) )?\\(?(.*?):(\\d+)(?::(\\d+))?\\)?\\s*$/i;\n\nfunction parseNode(line) {\n var parts = nodeRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n return {\n file: parts[2],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: [],\n lineNumber: +parts[3],\n column: parts[4] ? +parts[4] : null\n };\n}\n\nexport { parse };\n", "import { pathToPosix } from '@prisma/internals'\nimport * as stackTraceParser from 'stacktrace-parser'\n\nimport { ErrorFormat } from '../getPrismaClient'\n\ndeclare global {\n /**\n * a global variable that is injected by us via jest to make our snapshots\n * work in clients that cannot read from disk (e.g. wasm or edge clients)\n */\n let $EnabledCallSite: typeof EnabledCallSite | undefined\n}\n\nexport type LocationInFile = {\n fileName: string\n lineNumber: number | null\n columnNumber: number | null\n}\n\nexport interface CallSite {\n getLocation(): LocationInFile | null\n}\n\nclass DisabledCallSite implements CallSite {\n getLocation(): LocationInFile | null {\n return null\n }\n}\n\nexport class EnabledCallSite implements CallSite {\n private _error: Error\n constructor() {\n this._error = new Error()\n }\n getLocation(): LocationInFile | null {\n const stack = this._error.stack\n if (!stack) {\n return null\n }\n const stackFrames = stackTraceParser.parse(stack)\n // TODO: more resilient logic to check that it's not relative to cwd\n const frame = stackFrames.find((t) => {\n // Here we are trying to find the location in the user's code which caused the error\n if (!t.file) {\n return false\n }\n\n // convert windows path to posix path\n const posixFile = pathToPosix(t.file)\n return (\n posixFile !== '<anonymous>' && // Ignore as we can not read an <anonymous> file\n !posixFile.includes('@prisma') && // Internal, unbundled code\n !posixFile.includes('/packages/client/src/runtime/') && // Runtime sources when source maps are used\n !posixFile.endsWith('/runtime/client.js') && // Bundled runtimes\n !posixFile.startsWith('internal/') && // We don't want internal nodejs files\n !t.methodName.includes('new ') && // \"new CallSite\" call and maybe other constructors\n !t.methodName.includes('getCallSite') && // getCallSite function from this module\n !t.methodName.includes('Proxy.') && // Model proxies\n t.methodName.split('.').length < 4\n )\n })\n\n if (!frame || !frame.file) {\n return null\n }\n\n return {\n fileName: frame.file,\n lineNumber: frame.lineNumber,\n columnNumber: frame.column,\n }\n }\n}\n\nexport function getCallSite(errorFormat: ErrorFormat): CallSite {\n if (errorFormat === 'minimal' || TARGET_BUILD_TYPE === 'wasm-compiler-edge') {\n if (typeof $EnabledCallSite === 'function' && errorFormat !== 'minimal') {\n return new $EnabledCallSite()\n } else {\n return new DisabledCallSite()\n }\n } else {\n return new EnabledCallSite()\n }\n}\n", "export const aggregateMap = {\n _avg: true,\n _count: true,\n _sum: true,\n _min: true,\n _max: true,\n}\n", "import type { UserArgs } from '../../request/UserArgs'\nimport type { ModelAction } from '../applyModel'\nimport { aggregateMap } from './utils/aggregateMap'\n\n/**\n * Transforms the `userArgs` for the `.aggregate` shorthand. It is an API sugar\n * for not having to do things like: `{select: {_avg: {select: {age: true}}}}`.\n * The goal here is to desugar it into something that is understood by the QE.\n * @param args to transform\n * @returns\n */\nexport function desugarUserArgs(args: UserArgs = {}) {\n const _args = desugarCountInUserArgs(args)\n const userArgsEntries = Object.entries(_args)\n\n return userArgsEntries.reduce(\n (aggregateArgs, [key, value]) => {\n if (aggregateMap[key] !== undefined) {\n // if it's an aggregate, we re-wrap into select\n aggregateArgs['select']![key] = { select: value }\n } else {\n aggregateArgs[key] = value // or leave it alone\n }\n\n return aggregateArgs\n },\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n { select: {} } as UserArgs & { select: UserArgs },\n )\n}\n\n/**\n * Desugar `userArgs` when it contains `{_count: true}`.\n * @param args the user input\n * @returns\n */\nfunction desugarCountInUserArgs(args: UserArgs = {}) {\n if (typeof args['_count'] === 'boolean') {\n return { ...args, _count: { _all: args['_count'] } }\n }\n\n return args\n}\n\n/**\n * Creates an unpacker that adds sugar to the basic result of the QE. An\n * unpacker helps to transform a result before returning it to the user.\n * @param args the user input\n * @returns\n */\nexport function createUnpacker(args: UserArgs = {}) {\n return (data: object) => {\n if (typeof args['_count'] === 'boolean') {\n data['_count'] = data['_count']['_all']\n }\n\n return data\n }\n}\n\n/**\n * Executes the `.aggregate` action on a model.\n * @see {desugarUserArgs}\n * @param args the user input to desugar\n * @param modelAction a callback action that triggers request execution\n * @returns\n */\nexport function aggregate(args: UserArgs, modelAction: ModelAction) {\n const aggregateUnpacker = createUnpacker(args)\n\n return modelAction({\n action: 'aggregate',\n unpacker: aggregateUnpacker,\n argsMapper: desugarUserArgs,\n })(args)\n}\n", "import type { UserArgs } from '../../request/UserArgs'\nimport type { ModelAction } from '../applyModel'\nimport { createUnpacker as createUnpackerAggregate, desugarUserArgs as desugarUserArgsAggregate } from './aggregate'\n\n/**\n * Transforms the `userArgs` for the `.count` shorthand. It is an API sugar. It\n * reuses the logic from the `.aggregate` shorthand to add additional handling.\n * The goal here is to desugar it into something that is understood by the QE.\n * @param args to transform\n * @returns\n */\nfunction desugarUserArgs(args: UserArgs = {}) {\n const { select, ..._args } = args // exclude select\n\n if (typeof select === 'object') {\n return desugarUserArgsAggregate({ ..._args, _count: select })\n } else {\n return desugarUserArgsAggregate({ ..._args, _count: { _all: true } })\n }\n}\n\n/**\n * Creates an unpacker that adds sugar to the basic result of the QE. An\n * unpacker helps to transform a result before returning it to the user.\n * @param args the user input\n * @returns\n */\nexport function createUnpacker(args: UserArgs = {}) {\n if (typeof args['select'] === 'object') {\n return (data: object) => createUnpackerAggregate(args)(data)['_count']\n } else {\n return (data: object) => createUnpackerAggregate(args)(data)['_count']['_all']\n }\n}\n\n/**\n * Executes the `.count` action on a model via {@link aggregate}.\n * @param args the user input to desugar\n * @param modelAction a callback action that triggers request execution\n * @returns\n */\nexport function count(args: UserArgs, modelAction: ModelAction) {\n return modelAction({\n action: 'count',\n unpacker: createUnpacker(args),\n argsMapper: desugarUserArgs,\n })(args)\n}\n", "import type { UserArgs } from '../../request/UserArgs'\nimport type { ModelAction } from '../applyModel'\nimport { desugarUserArgs as desugarUserArgsAggregate } from './aggregate'\n\n/**\n * Transforms the `userArgs` for the `.groupBy` shorthand. It is an API sugar.\n * It reuses the logic from the `.aggregate` shorthand and adds additional\n * handling for the `by` clause. The goal here is to desugar it into something\n * that is understood by the QE.\n * @param args to transform\n * @returns\n */\nfunction desugarUserArgs(args: UserArgs = {}) {\n const _args = desugarUserArgsAggregate(args)\n\n // we desugar the array into { [key]: boolean }\n if (Array.isArray(_args['by'])) {\n for (const key of _args['by']) {\n if (typeof key === 'string') {\n _args['select'][key] = true\n }\n }\n } else if (typeof _args['by'] === 'string') {\n _args['select'][_args['by']] = true\n }\n\n return _args\n}\n\n/**\n * Creates an unpacker that adds sugar to the basic result of the QE. An\n * unpacker helps to transform a result before returning it to the user.\n * @param args the user input\n * @returns\n */\nexport function createUnpacker(args: UserArgs = {}) {\n return (data: object[]) => {\n if (typeof args?.['_count'] === 'boolean') {\n data.forEach((row) => {\n row['_count'] = row['_count']['_all']\n })\n }\n\n return data\n }\n}\n\n/**\n * Executes the `.groupBy` action on a model by reusing {@link aggregate}.\n * @param args the user input to desugar\n * @param modelAction a callback action that triggers request execution\n * @returns\n */\nexport function groupBy(args: UserArgs, modelAction: ModelAction) {\n return modelAction({\n action: 'groupBy',\n unpacker: createUnpacker(args),\n argsMapper: desugarUserArgs,\n })(args)\n}\n", "import type { Client } from '../../getPrismaClient'\nimport type { UserArgs } from '../request/UserArgs'\nimport { Action } from '../types/exported/JsApi'\nimport { aggregate } from './aggregates/aggregate'\nimport { count } from './aggregates/count'\nimport { groupBy } from './aggregates/groupBy'\nimport type { ModelAction } from './applyModel'\n\n/**\n * Dynamically returns the appropriate aggregate action for a given `action`.\n * With this, we are able to provide an aggregate api that has a better DX. In\n * short, we manipulate the user input which is designed to have DX to transform\n * it into something that the engines understand. Similarly, we take the engine\n * output for that input and produce something that is easier to work with.\n * @param action that tells which aggregate action to execute\n * @param modelAction a callback action that triggers request execution\n * @returns\n */\nexport function applyAggregates(client: Client, action: Action, modelAction: ModelAction) {\n // we effectively take over the aggregate api to perform data changes\n if (action === 'aggregate') return (userArgs?: UserArgs) => aggregate(userArgs, modelAction)\n if (action === 'count') return (userArgs?: UserArgs) => count(userArgs, modelAction)\n if (action === 'groupBy') return (userArgs?: UserArgs) => groupBy(userArgs, modelAction)\n\n return undefined\n}\n", "import { keyBy, RuntimeModel } from '@prisma/client-common'\n\nimport { FieldRefImpl } from './FieldRef'\nimport { defaultProxyHandlers } from './utils/defaultProxyHandlers'\n\nexport type FieldProxy = {\n readonly [key: string]: FieldRefImpl<string, string>\n}\n\nexport function applyFieldsProxy(modelName: string, model: RuntimeModel): FieldProxy {\n const scalarFieldsList = model.fields.filter((field) => !field.relationName)\n const scalarFields = keyBy(scalarFieldsList, 'name')\n return new Proxy(\n {},\n {\n get(target, prop) {\n if (prop in target || typeof prop === 'symbol') {\n return target[prop]\n }\n const dmmfField = scalarFields[prop]\n if (dmmfField) {\n return new FieldRefImpl(modelName, prop, dmmfField.type, dmmfField.isList, dmmfField.kind === 'enum')\n }\n\n return undefined\n },\n ...defaultProxyHandlers(Object.keys(scalarFields)),\n },\n )\n}\n", "// Taken from https://gist.github.com/LukeChannings/15c92cef5a016a8b21a0\n\n// ensure the keys being passed is an array of key paths\n// example: 'a.b' becomes ['a', 'b'] unless it was already ['a', 'b']\nconst keys = (ks: string | string[]) => (Array.isArray(ks) ? ks : ks.split('.'))\n\n// traverse the set of keys left to right,\n// returning the current value in each iteration.\n// if at any point the value for the current key does not exist,\n// return the default value\nexport const deepGet = (o, kp: string[]) => keys(kp).reduce((o, k) => o && o[k], o)\n\n// traverse the set of keys right to left,\n// returning a new object containing both properties from the object\n// we were originally passed and our new property.\n//\n// Example:\n// If o = { a: { b: { c: 1 } } }\n//\n// deepSet(o, ['a', 'b', 'c'], 2) will progress thus:\n// 1. c = Object.assign({}, {c: 1}, { c: 2 })\n// 2. b = Object.assign({}, { b: { c: 1 } }, { b: c })\n// 3. returned = Object.assign({}, { a: { b: { c: 1 } } }, { a: b })\nexport const deepSet = (o: any, kp: string | string[], v: any) =>\n keys(kp).reduceRight((v, k, i, ks) => Object.assign({}, deepGet(o, ks.slice(0, i)), { [k]: v }), v)\n", "import type * as DMMF from '@prisma/dmmf'\n\nimport type { Client } from '../../getPrismaClient'\nimport { getCallSite } from '../../utils/CallSite'\nimport { deepSet } from '../../utils/deep-set'\nimport type { UserArgs } from '../request/UserArgs'\nimport type { ModelAction } from './applyModel'\nimport { defaultProxyHandlers } from './utils/defaultProxyHandlers'\n\n/**\n * The fluent API makes that nested relations can be retrieved at once. It's a\n * helper for writing `select` statements on relations with a chaining api.\n * Because of this, we automatically add `select` statements to the query, that\n * also means that we need to provide a `dataPath` for unpacking nested values.\n * @see {getNextUserArgs}\n * @param dmmfModelName\n * @param prevDataPath\n * @returns\n */\nfunction getNextDataPath(fluentPropName?: string, prevDataPath?: string[]) {\n if (fluentPropName === undefined || prevDataPath === undefined) return []\n\n return [...prevDataPath, 'select', fluentPropName]\n}\n\n/**\n * @see {getNextDataPath} for introduction. The goal of the fluent API is to\n * make it easy to retrieve nested relations. For this, we construct the query\n * args that are necessary to retrieve the nested relations. It consists of\n * nesting `select` statements each time that we access a relation.\n * @param callArgs usually passed on the last call of the chaining api\n * @param prevArgs when multiple chaining occurs, they are the previous\n * @param nextDataPath path where to set `callArgs` in `prevArgs`\n * @example\n * ```ts\n * prisma.user.findUnique().link().user()\n *\n * // will end up with an args like this:\n * // args {\n * // \"where\": {\n * // \"email\": \"1639498523518@gmail.com\"\n * // },\n * // \"select\": {\n * // \"link\": {\n * // \"select\": {\n * // \"user\": true\n * // }\n * // }\n * // }\n * // }\n * ```\n */\nfunction getNextUserArgs(callArgs: UserArgs, prevArgs: UserArgs, nextDataPath: string[]): UserArgs {\n if (prevArgs === undefined) return callArgs ?? {}\n\n return deepSet(prevArgs, nextDataPath, callArgs || true)\n}\n\n/**\n * Dynamically creates a fluent API from a `modelAction` and a `dmmfModelName`.\n * We use the current `dmmfModelName` to determine what can be chained on next.\n * The fluent API allows to chain on model relations to provide an alternative\n * way to fetch and access nested data all at once. When triggered, it calls\n * `modelActions` after having accumulated `prevDataPath` and `prevUserArgs`\n * with the chaining. You can find an example of usage at {@link applyModel}.\n * @param client to provide dmmf information\n * @param dmmfModelName the dmmf name of the model to apply the api to\n * @param modelAction a callback action that triggers request execution\n * @param fluentPropName the name of the api link that was just called\n * @param prevDataPath the dataPath from the previous api link\n * @param prevUserArgs the userArgs from the previous api link\n * @remarks optional parameters are empty on the first call via\n * {@link applyModel}\n * @returns\n */\nexport function applyFluent(\n client: Client,\n dmmfModelName: string,\n modelAction: ModelAction,\n fluentPropName?: string,\n prevDataPath?: string[],\n prevUserArgs?: UserArgs,\n) {\n // we retrieve the model that is described from the DMMF\n const dmmfModel = client._runtimeDataModel.models[dmmfModelName]\n\n // map[field.name] === field, basically for quick access\n const dmmfModelFieldMap = dmmfModel.fields.reduce(\n (acc, field) => ({ ...acc, [field.name]: field }),\n {} as { [dmmfModelFieldName: string]: DMMF.Field },\n )\n\n // we return a regular model action but proxy its return\n return (userArgs?: UserArgs) => {\n const callsite = getCallSite(client._errorFormat)\n // ! first call: nextDataPath => [], nextUserArgs => userArgs\n const nextDataPath = getNextDataPath(fluentPropName, prevDataPath)\n const nextUserArgs = getNextUserArgs(userArgs, prevUserArgs, nextDataPath)\n const prismaPromise = modelAction({ dataPath: nextDataPath, callsite })(nextUserArgs)\n // TODO: use an unpacker here instead of ClientFetcher logic\n // TODO: once it's done we can deprecate the use of dataPath\n const ownKeys = getOwnKeys(client, dmmfModelName)\n\n // we take control of the return promise to allow chaining\n return new Proxy(prismaPromise, {\n get(target, prop: string) {\n // fluent api only works on fields that are relational\n if (!ownKeys.includes(prop)) return target[prop]\n\n // here we are sure that prop is a field of type object\n const dmmfModelName = dmmfModelFieldMap[prop].type\n const modelArgs = [dmmfModelName, modelAction, prop] as const\n const dataArgs = [nextDataPath, nextUserArgs] as const\n\n // we allow for chaining more with this recursive call\n return applyFluent(client, ...modelArgs, ...dataArgs)\n },\n ...defaultProxyHandlers([...ownKeys, ...Object.getOwnPropertyNames(prismaPromise)]),\n })\n }\n}\n\n// the only accessible fields are relations to be chained on\nfunction getOwnKeys(client: Client, dmmfModelName: string) {\n return client._runtimeDataModel.models[dmmfModelName].fields\n .filter((field) => field.kind === 'object') // relations\n .map((field) => field.name)\n}\n", "import * as DMMF from '@prisma/dmmf'\nimport type { O } from 'ts-toolbelt'\n\nimport { type Client, type InternalRequestParams } from '../../getPrismaClient'\nimport { getCallSite } from '../../utils/CallSite'\nimport {\n addObjectProperties,\n addProperty,\n cacheProperties,\n CompositeProxyLayer,\n createCompositeProxy,\n} from '../compositeProxy'\nimport type { PrismaPromise } from '../request/PrismaPromise'\nimport type { UserArgs } from '../request/UserArgs'\nimport { applyAggregates } from './applyAggregates'\nimport { applyFieldsProxy } from './applyFieldsProxy'\nimport { applyFluent } from './applyFluent'\nimport { dmmfToJSModelName } from './utils/dmmfToJSModelName'\n\nexport type ModelAction = (\n paramOverrides: O.Optional<InternalRequestParams>,\n) => (userArgs?: UserArgs) => PrismaPromise<unknown>\n\nconst fluentProps = [\n 'findUnique',\n 'findUniqueOrThrow',\n 'findFirst',\n 'findFirstOrThrow',\n 'create',\n 'update',\n 'upsert',\n 'delete',\n] as const\nconst aggregateProps = ['aggregate', 'count', 'groupBy'] as const\n\n/**\n * Dynamically creates a model interface via a proxy.\n * @param client to trigger the request execution\n * @param dmmfModelName the dmmf name of the model\n * @returns\n */\nexport function applyModel(client: Client, dmmfModelName: string) {\n const modelExtensions = client._extensions.getAllModelExtensions(dmmfModelName) ?? {}\n\n const layers = [\n modelActionsLayer(client, dmmfModelName),\n fieldsPropertyLayer(client, dmmfModelName),\n addObjectProperties(modelExtensions),\n addProperty('name', () => dmmfModelName),\n addProperty('$name', () => dmmfModelName),\n addProperty('$parent', () => client._appliedParent),\n ]\n\n return createCompositeProxy({}, layers)\n}\n\n/**\n * Dynamically creates a model interface via a proxy.\n * @param client to trigger the request execution\n * @param dmmfModelName the dmmf name of the model\n * @returns\n */\nfunction modelActionsLayer(client: Client, dmmfModelName: string): CompositeProxyLayer<string> {\n // we use the javascript model name for display purposes\n const jsModelName = dmmfToJSModelName(dmmfModelName)\n const ownKeys = Object.keys(DMMF.ModelAction).concat('count')\n\n return {\n getKeys() {\n return ownKeys\n },\n\n getPropertyValue(key) {\n const dmmfActionName = key as DMMF.ModelAction\n\n // we return a function as the model action that we want to expose\n // it takes user args and executes the request in a Prisma Promise\n const action = (paramOverrides: O.Optional<InternalRequestParams>) => (userArgs?: UserArgs) => {\n const callSite = getCallSite(client._errorFormat) // used for showing better errors\n\n return client._createPrismaPromise(\n (transaction) => {\n const params: InternalRequestParams = {\n // data and its dataPath for nested results\n args: userArgs,\n dataPath: [],\n\n // action name and its related model\n action: dmmfActionName,\n model: dmmfModelName,\n\n // method name for display only\n clientMethod: `${jsModelName}.${key}`,\n jsModelName,\n\n // transaction information\n transaction,\n\n // stack trace\n callsite: callSite,\n }\n\n return client._request({ ...params, ...paramOverrides })\n },\n {\n action: dmmfActionName,\n args: userArgs,\n model: dmmfModelName,\n },\n )\n }\n\n // we give the control over action for building the fluent api\n if ((fluentProps as readonly string[]).includes(dmmfActionName)) {\n return applyFluent(client, dmmfModelName, action)\n }\n\n // we handle the edge case of aggregates that need extra steps\n if (isValidAggregateName(key)) {\n return applyAggregates(client, key, action)\n }\n\n return action({}) // and by default, don't override any params\n },\n }\n}\n\nfunction isValidAggregateName(action: string): action is (typeof aggregateProps)[number] {\n return (aggregateProps as readonly string[]).includes(action)\n}\n\nfunction fieldsPropertyLayer(client: Client, dmmfModelName: string) {\n return cacheProperties(\n addProperty('fields', () => {\n const model = client._runtimeDataModel.models[dmmfModelName]\n return applyFieldsProxy(dmmfModelName, model)\n }),\n )\n}\n", "/**\n * Transforms a model name coming from the runtime to a DMMF model name.\n * @param name\n * @returns\n */\nexport function jsToDMMFModelName(name: string) {\n return name.replace(/^./, (str) => str.toUpperCase())\n}\n", "import type { Client } from '../../getPrismaClient'\nimport {\n addObjectProperties,\n addProperty,\n cacheProperties,\n CompositeProxyLayer,\n createCompositeProxy,\n} from '../compositeProxy'\nimport { applyModel } from './applyModel'\nimport { dmmfToJSModelName } from './utils/dmmfToJSModelName'\nimport { jsToDMMFModelName } from './utils/jsToDMMFModelName'\n\n// symbol we use for storing raw, unproxied\n// client instance, so we later can retrieve it\n// via `unapplyModels` methods\nconst rawClient = Symbol()\n\n/**\n * Dynamically creates a model proxy interface for a give name. For each prop\n * accessed on this proxy, it will lookup the dmmf to find if that model exists.\n * If it is the case, it will create a proxy for that model via {@link applyModel}.\n * @param client to create the proxy around\n * @returns a proxy to access models\n */\nexport function applyModelsAndClientExtensions(client: Client) {\n const layers = [\n rootLayer(client),\n modelsLayer(client),\n addProperty(rawClient, () => client),\n addProperty('$parent', () => client._appliedParent),\n ]\n const clientExtensions = client._extensions.getAllClientExtensions()\n if (clientExtensions) {\n layers.push(addObjectProperties(clientExtensions))\n }\n return createCompositeProxy(client, layers)\n}\n\nfunction rootLayer(client: Client): CompositeProxyLayer {\n const prototype = Object.getPrototypeOf(client._originalClient)\n const allKeys = [...new Set(Object.getOwnPropertyNames(prototype))]\n\n return {\n getKeys() {\n return allKeys\n },\n\n getPropertyValue(prop) {\n return client[prop]\n },\n }\n}\n\nfunction modelsLayer(client: Client): CompositeProxyLayer {\n const dmmfModelKeys = Object.keys(client._runtimeDataModel.models)\n const jsModelKeys = dmmfModelKeys.map(dmmfToJSModelName)\n const allKeys = [...new Set(dmmfModelKeys.concat(jsModelKeys))]\n\n return cacheProperties({\n getKeys() {\n return allKeys\n },\n\n getPropertyValue(prop) {\n const dmmfModelName = jsToDMMFModelName(prop)\n // creates a new model proxy on the fly and caches it\n if (client._runtimeDataModel.models[dmmfModelName] !== undefined) {\n return applyModel(client, dmmfModelName)\n }\n\n // above silently failed if model name is lower cased\n if (client._runtimeDataModel.models[prop] !== undefined) {\n return applyModel(client, prop)\n }\n\n return undefined\n },\n\n getPropertyDescriptor(key) {\n if (!jsModelKeys.includes(key)) {\n return { enumerable: false }\n }\n\n return undefined\n },\n })\n}\n\nexport function unApplyModelsAndClientExtensions(client: Client): Client {\n if (client[rawClient]) {\n return client[rawClient]\n }\n return client\n}\n", "import { Client } from '../../getPrismaClient'\nimport { applyModelsAndClientExtensions } from '../model/applyModelsAndClientExtensions'\nimport { ExtensionArgs } from '../types/exported'\n\n/**\n * @param this\n */\nexport function $extends(this: Client, extension: ExtensionArgs | ((client: Client) => Client)): Client {\n if (typeof extension === 'function') {\n return extension(this)\n }\n\n const newClient = Object.create(this._originalClient, {\n _extensions: { value: this._extensions.append(extension) },\n _appliedParent: { value: this, configurable: true },\n $on: { value: undefined },\n }) as Client\n\n return applyModelsAndClientExtensions(newClient)\n}\n", "import { hasOwnProperty } from '@prisma/internals'\n\nimport {\n addProperty,\n cacheProperties,\n CompositeProxyLayer,\n createCompositeProxy,\n removeProperties,\n} from '../compositeProxy'\nimport { Omission, Selection } from '../types/exported/JsApi'\nimport { MergedExtensionsList } from './MergedExtensionsList'\nimport { ComputedField } from './resultUtils'\n\ntype ApplyExtensionsArgs = {\n result: object\n select?: Selection\n omit?: Omission\n modelName: string\n extensions: MergedExtensionsList\n}\n\n/**\n * Given a part of a query result, it's model name and a list of extension,\n * applies computed fields to the results. Fields are computed lazily on a first access,\n * after that the result of computation is cached. In case `select` is used, all dependencies\n * of the computed fields would be excluded from final result, unless they are also specified in the select.\n *\n * This function applies computed fields to a single object only: it does not traverse relationships.\n * For full functionality, it is meant to be combined with `visitQueryResult`.\n *\n * @param params\n * @returns\n */\nexport function applyResultExtensions({ result, modelName, select, omit, extensions }: ApplyExtensionsArgs) {\n const computedFields = extensions.getAllComputedFields(modelName)\n if (!computedFields) {\n return result\n }\n\n const computedPropertiesLayers: CompositeProxyLayer[] = []\n const maskingLayers: CompositeProxyLayer[] = []\n\n for (const field of Object.values(computedFields)) {\n if (omit) {\n if (omit[field.name]) {\n continue\n }\n const toMask = field.needs.filter((prop) => omit[prop])\n if (toMask.length > 0) {\n maskingLayers.push(removeProperties(toMask))\n }\n } else if (select) {\n if (!select[field.name]) {\n continue\n }\n\n const toMask = field.needs.filter((prop) => !select[prop])\n if (toMask.length > 0) {\n maskingLayers.push(removeProperties(toMask))\n }\n }\n\n if (areNeedsMet(result, field.needs)) {\n computedPropertiesLayers.push(\n computedPropertyLayer(field, createCompositeProxy(result, computedPropertiesLayers)),\n )\n }\n }\n\n if (computedPropertiesLayers.length > 0 || maskingLayers.length > 0) {\n return createCompositeProxy(result, [...computedPropertiesLayers, ...maskingLayers])\n }\n return result\n}\n\nfunction areNeedsMet(result: object, neededProperties: string[]) {\n return neededProperties.every((property) => hasOwnProperty(result, property))\n}\n\nfunction computedPropertyLayer(field: ComputedField, result: object): CompositeProxyLayer {\n return cacheProperties(addProperty(field.name, () => field.compute(result)))\n}\n", "import { RuntimeDataModel } from '@prisma/client-common'\n\nimport { isSkip } from '../types'\nimport { JsArgs, Selection } from '../types/exported/JsApi'\n\ntype ModelVisitor = (value: object, modelName: string, queryArgs: JsArgs) => object | undefined\n\ntype VisitParams = {\n result: object\n args: JsArgs\n modelName: string\n runtimeDataModel: RuntimeDataModel\n visitor: ModelVisitor\n}\n\n/**\n * Function recursively walks through provided query response using `include` and `select`\n * query parameters and calls `visitor` callback for each model it encounters.\n * `visitor` receives the value of a particular response section, model it corresponds to and\n * the arguments used to query it. If visitor returns any non-undefined value that value will\n * replace corresponding part of the final result.\n *\n * @param params\n * @returns\n */\nexport function visitQueryResult({ visitor, result, args, runtimeDataModel, modelName }: VisitParams) {\n if (Array.isArray(result)) {\n for (let i = 0; i < result.length; i++) {\n result[i] = visitQueryResult({\n result: result[i],\n args,\n modelName,\n runtimeDataModel,\n visitor,\n })\n }\n return result\n }\n const visitResult = visitor(result, modelName, args) ?? result\n if (args.include) {\n visitNested({\n includeOrSelect: args.include,\n result: visitResult,\n parentModelName: modelName,\n runtimeDataModel,\n visitor,\n })\n }\n if (args.select) {\n visitNested({\n includeOrSelect: args.select,\n result: visitResult,\n parentModelName: modelName,\n runtimeDataModel,\n visitor,\n })\n }\n return visitResult\n}\n\ntype VisitNestedParams = {\n includeOrSelect: Selection\n result: object\n parentModelName: string\n runtimeDataModel: RuntimeDataModel\n visitor: ModelVisitor\n}\n\nfunction visitNested({ includeOrSelect, result, parentModelName, runtimeDataModel, visitor }: VisitNestedParams) {\n for (const [fieldName, subConfig] of Object.entries(includeOrSelect)) {\n if (!subConfig || result[fieldName] == null || isSkip(subConfig)) {\n continue\n }\n const parentModel = runtimeDataModel.models[parentModelName]\n const field = parentModel.fields.find((field) => field.name === fieldName)\n if (!field || field.kind !== 'object' || !field.relationName) {\n continue\n }\n const args = typeof subConfig === 'object' ? subConfig : {}\n result[fieldName] = visitQueryResult({\n visitor,\n result: result[fieldName],\n args,\n modelName: field.type,\n runtimeDataModel,\n })\n }\n}\n", "import { RuntimeDataModel } from '@prisma/client-common'\n\nimport { GlobalOmitOptions } from '../jsonProtocol/serializeJsonQuery'\nimport { dmmfToJSModelName } from '../model/utils/dmmfToJSModelName'\nimport { JsArgs } from '../types/exported/JsApi'\nimport { applyResultExtensions } from './applyResultExtensions'\nimport { MergedExtensionsList } from './MergedExtensionsList'\nimport { visitQueryResult } from './visitQueryResult'\n\ntype ApplyAllResultExtensionsParams = {\n result: object | null\n modelName: string\n args: JsArgs\n extensions: MergedExtensionsList\n runtimeDataModel: RuntimeDataModel\n globalOmit?: GlobalOmitOptions\n}\n\n/**\n * Walks the result of the query and applies all possible result extensions\n * to all parts of it, including nested relations\n */\nexport function applyAllResultExtensions({\n result,\n modelName,\n args,\n extensions,\n runtimeDataModel,\n globalOmit,\n}: ApplyAllResultExtensionsParams) {\n // We return the result directly (not applying result extensions) if\n // - there is no extension to apply\n // - result is `null`\n // - result is not an object (e.g. `.count()`)\n if (extensions.isEmpty() || result == null || typeof result !== 'object') {\n return result\n }\n const model = runtimeDataModel.models[modelName]\n if (!model) {\n return result\n }\n\n return visitQueryResult({\n result,\n args: args ?? {},\n modelName,\n runtimeDataModel,\n visitor: (value, dmmfModelName, args) => {\n const jsName = dmmfToJSModelName(dmmfModelName)\n return applyResultExtensions({\n result: value,\n modelName: jsName,\n select: args.select,\n // passing omit only if explicit select is not set - those 2 options are\n // mutually exclusive\n omit: args.select ? undefined : { ...globalOmit?.[jsName], ...args.omit },\n extensions,\n })\n },\n })\n}\n", "import { Decimal, ObjectEnumValue, Sql } from '@prisma/client-runtime-utils'\nimport { assertNever } from '@prisma/internals'\n\nimport { isFieldRef } from '../core/model/FieldRef'\nimport { isTypedSql, TypedSql, UnknownTypedSql } from '../core/types/exported'\nimport { JsArgs, JsInputValue } from '../core/types/exported/JsApi'\nimport { RawQueryArgs } from '../core/types/exported/RawQueryArgs'\nimport { isDate } from './date'\nimport { isDecimalJsLike } from './decimalJsLike'\n\nexport function deepCloneArgs(args: JsArgs | RawQueryArgs): JsArgs | RawQueryArgs {\n if (args instanceof Sql) {\n return cloneSql(args)\n }\n\n if (isTypedSql(args)) {\n return cloneTypedSql(args)\n }\n\n if (Array.isArray(args)) {\n const clone: RawQueryArgs = [args[0]]\n\n for (let i = 1; i < args.length; i++) {\n clone[i] = deepCloneValue(args[i] as JsInputValue)\n }\n\n return clone\n }\n const clone: JsArgs = {}\n for (const k in args) {\n clone[k] = deepCloneValue(args[k])\n }\n return clone\n}\n\nfunction cloneSql(rawParam: Sql): Sql {\n return new Sql(rawParam.strings, rawParam.values)\n}\n\nfunction cloneTypedSql(rawParam: UnknownTypedSql): UnknownTypedSql {\n return new TypedSql(rawParam.sql, rawParam.values)\n}\n\n// based on https://github.com/lukeed/klona/blob/v2.0.6/src/index.js\nfunction deepCloneValue(x: JsInputValue): JsInputValue {\n if (typeof x !== 'object' || x == null || x instanceof ObjectEnumValue || isFieldRef(x)) {\n return x\n }\n\n if (isDecimalJsLike(x)) {\n return new Decimal(x.toFixed())\n }\n\n if (isDate(x)) {\n return new Date(+x)\n }\n\n if (ArrayBuffer.isView(x)) {\n return x.slice(0)\n }\n\n if (Array.isArray(x)) {\n let k = x.length\n let copy\n for (copy = Array(k); k--; ) {\n copy[k] = deepCloneValue(x[k])\n }\n return copy\n }\n\n if (typeof x === 'object') {\n const copy = {}\n for (const k in x) {\n if (k === '__proto__') {\n Object.defineProperty(copy, k, {\n value: deepCloneValue(x[k]),\n configurable: true,\n enumerable: true,\n writable: true,\n })\n } else {\n copy[k] = deepCloneValue(x[k])\n }\n }\n return copy\n }\n\n assertNever(x, 'Unknown value')\n}\n", "const denylist = ['$connect', '$disconnect', '$on', '$transaction', '$extends'] as const\n\nexport const itxClientDenyList = denylist as ReadonlyArray<string | symbol>\n\nexport type ITXClientDenyList = (typeof denylist)[number]\n", "import { Client, InternalRequestParams } from '../../getPrismaClient'\nimport { RequestParams } from '../../RequestHandler'\nimport { deepCloneArgs } from '../../utils/deepCloneArgs'\nimport { AccelerateExtensionFetchDecorator } from '../engines'\nimport { QueryOptionsCb } from '../types/exported/ExtensionArgs'\nimport { BatchInternalParams, BatchQueryOptionsCb } from '../types/internal/ExtensionsInternalArgs'\n\nfunction iterateAndCallQueryCallbacks(\n client: Client,\n params: InternalRequestParams,\n queryCbs: QueryOptionsCb[],\n i = 0,\n) {\n return client._createPrismaPromise((transaction) => {\n // we need to keep track of the previous customDataProxyFetch\n const prevCustomFetch = params.customDataProxyFetch\n\n // allow query extensions to re-wrap in transactions\n // this will automatically discard the prev batch tx\n if ('transaction' in params && transaction !== undefined) {\n if (params.transaction?.kind === 'batch') {\n void params.transaction.lock.then() // discard\n }\n params.transaction = transaction\n }\n\n // if we are done recursing, we execute the request\n if (i === queryCbs.length) {\n return client._executeRequest(params)\n }\n\n // if not, call the next query cb and recurse query\n return queryCbs[i]({\n model: params.model,\n operation: params.model ? params.action : params.clientMethod,\n args: deepCloneArgs(params.args ?? {}),\n // @ts-expect-error because not part of public API\n __internalParams: params,\n query: (args, __internalParams = params) => {\n // we need to keep track of the current customDataProxyFetch\n // this is to cascade customDataProxyFetch like a middleware\n const currCustomFetch = __internalParams.customDataProxyFetch\n __internalParams.customDataProxyFetch = composeCustomDataProxyFetch(prevCustomFetch, currCustomFetch)\n __internalParams.args = args\n\n return iterateAndCallQueryCallbacks(client, __internalParams, queryCbs, i + 1)\n },\n })\n })\n}\n\nexport function applyQueryExtensions(client: Client, params: InternalRequestParams): Promise<any> {\n const { jsModelName, action, clientMethod } = params\n const operation = jsModelName ? action : clientMethod\n\n // query extensions only apply to model-bound operations\n if (client._extensions.isEmpty()) {\n return client._executeRequest(params)\n }\n\n // get the cached query cbs for a given model and action\n const cbs = client._extensions.getAllQueryCallbacks(jsModelName ?? '$none', operation)\n\n return iterateAndCallQueryCallbacks(client, params, cbs)\n}\n\ntype BatchExecuteCallback = (params: BatchInternalParams) => Promise<unknown[]>\n\nexport function createApplyBatchExtensionsFunction(executeBatch: BatchExecuteCallback) {\n return (requests: RequestParams[]) => {\n const params = { requests }\n const callbacks = requests[0].extensions.getAllBatchQueryCallbacks()\n if (!callbacks.length) {\n return executeBatch(params)\n }\n\n return iterateAndCallBatchCallbacks(params, callbacks, 0, executeBatch)\n }\n}\n\nexport function iterateAndCallBatchCallbacks(\n params: BatchInternalParams,\n callbacks: BatchQueryOptionsCb[],\n i: number,\n executeBatch: BatchExecuteCallback,\n) {\n if (i === callbacks.length) {\n return executeBatch(params)\n }\n\n const prevFetch = params.customDataProxyFetch\n const transaction = params.requests[0].transaction\n return callbacks[i]({\n args: {\n queries: params.requests.map((request) => ({\n model: request.modelName,\n operation: request.action,\n args: request.args,\n })),\n transaction: transaction\n ? {\n isolationLevel: transaction.kind === 'batch' ? transaction.isolationLevel : undefined,\n }\n : undefined,\n },\n __internalParams: params,\n query(_args, __internalParams = params) {\n const nextFetch = __internalParams.customDataProxyFetch\n __internalParams.customDataProxyFetch = composeCustomDataProxyFetch(prevFetch, nextFetch)\n return iterateAndCallBatchCallbacks(__internalParams, callbacks, i + 1, executeBatch)\n },\n })\n}\n\nconst noopFetch: AccelerateExtensionFetchDecorator = (f) => f\nfunction composeCustomDataProxyFetch(prevFetch = noopFetch, nextFetch = noopFetch): AccelerateExtensionFetchDecorator {\n return (f) => prevFetch(nextFetch(f))\n}\n", "import { Decimal } from '@prisma/client-runtime-utils'\n\nimport { assertNever } from './utils'\n\nexport type DateTaggedValue = { $type: 'DateTime'; value: string }\nexport type DecimalTaggedValue = { $type: 'Decimal'; value: string }\nexport type BytesTaggedValue = { $type: 'Bytes'; value: string }\nexport type BigIntTaggedValue = { $type: 'BigInt'; value: string }\nexport type FieldRefTaggedValue = { $type: 'FieldRef'; value: { _ref: string } }\nexport type EnumTaggedValue = { $type: 'Enum'; value: string }\nexport type JsonTaggedValue = { $type: 'Json'; value: string }\n\nexport type JsonInputTaggedValue =\n | DateTaggedValue\n | DecimalTaggedValue\n | BytesTaggedValue\n | BigIntTaggedValue\n | FieldRefTaggedValue\n | JsonTaggedValue\n | EnumTaggedValue\n\nexport type JsonOutputTaggedValue =\n | DateTaggedValue\n | DecimalTaggedValue\n | BytesTaggedValue\n | BigIntTaggedValue\n | JsonTaggedValue\n\nexport type JsOutputValue =\n | null\n | string\n | number\n | boolean\n | bigint\n | Uint8Array\n | Date\n | Decimal\n | JsOutputValue[]\n | { [key: string]: JsOutputValue }\n\nexport function normalizeJsonProtocolValues(result: unknown): unknown {\n if (result === null) {\n return result\n }\n\n if (Array.isArray(result)) {\n return result.map(normalizeJsonProtocolValues)\n }\n\n if (typeof result === 'object') {\n if (isTaggedValue(result)) {\n return normalizeTaggedValue(result)\n }\n\n if (ArrayBuffer.isView(result)) {\n const buffer = Buffer.from(result.buffer, result.byteOffset, result.byteLength)\n return buffer.toString('base64')\n }\n\n // avoid mapping class instances\n if (result.constructor !== null && result.constructor.name !== 'Object') {\n return result\n }\n\n return mapObjectValues(result, normalizeJsonProtocolValues)\n }\n\n return result\n}\n\nfunction isTaggedValue(value: unknown): value is JsonOutputTaggedValue {\n return value !== null && typeof value == 'object' && typeof value['$type'] === 'string'\n}\n\n/**\n * Normalizes the value inside a tagged value to match the snapshots in tests.\n * Sometimes there are multiple equally valid representations of the same value\n * (e.g. a decimal string may contain an arbitrary number of trailing zeros,\n * datetime strings may specify the UTC offset as either '+00:00' or 'Z', etc).\n * Since these differences have no effect on the actual values received from the\n * Prisma Client once the response is deserialized to JavaScript values, we don't\n * spend extra CPU cycles on normalizing them in the data mapper. Instead, we\n * patch and normalize them here to ensure they are consistent with the snapshots\n * in the query engine tests.\n */\nfunction normalizeTaggedValue({ $type, value }: JsonOutputTaggedValue): JsonOutputTaggedValue {\n switch ($type) {\n case 'BigInt':\n return { $type, value: String(value) }\n case 'Bytes':\n return { $type, value: Buffer.from(value, 'base64').toString('base64') }\n case 'DateTime':\n return { $type, value: new Date(value).toISOString() }\n case 'Decimal':\n return { $type, value: String(new Decimal(value)) }\n case 'Json':\n return { $type, value: JSON.stringify(JSON.parse(value)) }\n default:\n assertNever(value, 'Unknown tagged value')\n }\n}\n\nfunction mapObjectValues<K extends PropertyKey, T, U>(\n object: Record<K, T>,\n mapper: (value: T, key: K) => U,\n): Record<K, U> {\n const result = {} as Record<K, U>\n\n for (const key of Object.keys(object)) {\n result[key] = mapper(object[key] as T, key as K)\n }\n\n return result\n}\n\nexport function deserializeJsonResponse(result: unknown): unknown {\n if (result === null) {\n return result\n }\n\n if (Array.isArray(result)) {\n return result.map(deserializeJsonResponse)\n }\n\n if (typeof result === 'object') {\n if (isTaggedValue(result)) {\n return deserializeTaggedValue(result)\n }\n\n // avoid mapping class instances\n if (result.constructor !== null && result.constructor.name !== 'Object') {\n return result\n }\n\n return mapObjectValues(result, deserializeJsonResponse)\n }\n\n return result\n}\n\nfunction deserializeTaggedValue({ $type, value }: JsonOutputTaggedValue): JsOutputValue {\n switch ($type) {\n case 'BigInt':\n return BigInt(value)\n case 'Bytes': {\n const { buffer, byteOffset, byteLength } = Buffer.from(value, 'base64')\n return new Uint8Array(buffer, byteOffset, byteLength)\n }\n case 'DateTime':\n return new Date(value)\n case 'Decimal':\n return new Decimal(value)\n case 'Json':\n return JSON.parse(value)\n default:\n assertNever(value, 'Unknown tagged value')\n }\n}\n", "import { Decimal } from '@prisma/client-runtime-utils'\n\n// Copied over to avoid the heavy dependency on `@prisma/internals` with its\n// transitive dependencies that are not needed for other query plan executor\n// implementations outside of Prisma Client (e.g. test executor for query\n// engine tests and query plan executor for Accelerate) that also depend on\n// `@prisma/client-engine-runtime`.\nexport function assertNever(_: never, message: string): never {\n throw new Error(message)\n}\n\n/**\n * Checks if two objects are deeply equal, recursively checking all properties for strict equality.\n */\nexport function isDeepStrictEqual(a: unknown, b: unknown): boolean {\n return (\n a === b ||\n (a !== null &&\n b !== null &&\n typeof a === 'object' &&\n typeof b === 'object' &&\n Object.keys(a).length === Object.keys(b).length &&\n Object.keys(a).every((key) => isDeepStrictEqual(a[key], b[key])))\n )\n}\n\n/**\n * Checks if two objects representing the names and values of key columns match. A match is\n * defined by one of the sets of keys being a subset of the other. This function also\n * converts arguments to the types used by driver adapters if necessary.\n */\nexport function doKeysMatch(lhs: {}, rhs: {}): boolean {\n const lhsKeys = Object.keys(lhs)\n const rhsKeys = Object.keys(rhs)\n const smallerKeyList = lhsKeys.length < rhsKeys.length ? lhsKeys : rhsKeys\n\n return smallerKeyList.every((key) => {\n if (typeof lhs[key] === typeof rhs[key] && typeof lhs[key] !== 'object') {\n // fast path for primitive types\n return lhs[key] === rhs[key]\n }\n\n if (Decimal.isDecimal(lhs[key]) || Decimal.isDecimal(rhs[key])) {\n const lhsDecimal = asDecimal(lhs[key])\n const rhsDecimal = asDecimal(rhs[key])\n return lhsDecimal && rhsDecimal && lhsDecimal.equals(rhsDecimal)\n } else if (lhs[key] instanceof Uint8Array || rhs[key] instanceof Uint8Array) {\n const lhsBuffer = asBuffer(lhs[key])\n const rhsBuffer = asBuffer(rhs[key])\n return lhsBuffer && rhsBuffer && lhsBuffer.equals(rhsBuffer)\n } else if (lhs[key] instanceof Date || rhs[key] instanceof Date) {\n return asDate(lhs[key])?.getTime() === asDate(rhs[key])?.getTime()\n } else if (typeof lhs[key] === 'bigint' || typeof rhs[key] === 'bigint') {\n return asBigInt(lhs[key]) === asBigInt(rhs[key])\n } else if (typeof lhs[key] === 'number' || typeof rhs[key] === 'number') {\n return asNumber(lhs[key]) === asNumber(rhs[key])\n }\n\n return isDeepStrictEqual(lhs[key], rhs[key])\n })\n}\n\nfunction asDecimal(value: unknown): Decimal | undefined {\n if (Decimal.isDecimal(value)) {\n return value\n } else if (typeof value === 'number' || typeof value === 'string') {\n return new Decimal(value)\n } else {\n return\n }\n}\n\nfunction asBuffer(value: unknown): Buffer | undefined {\n if (Buffer.isBuffer(value)) {\n return value\n } else if (value instanceof Uint8Array) {\n return Buffer.from(value.buffer, value.byteOffset, value.byteLength)\n } else if (typeof value === 'string') {\n return Buffer.from(value, 'base64')\n } else {\n return\n }\n}\n\nfunction asDate(value: unknown): Date | undefined {\n if (value instanceof Date) {\n return value\n } else if (typeof value === 'string' || typeof value === 'number') {\n return new Date(value)\n } else {\n return\n }\n}\n\nfunction asBigInt(value: unknown): bigint | undefined {\n if (typeof value === 'bigint') {\n return value\n } else if (typeof value === 'number' || typeof value === 'string') {\n return BigInt(value)\n } else {\n return\n }\n}\n\nfunction asNumber(value: unknown): number | undefined {\n if (typeof value === 'number') {\n return value\n } else if (typeof value === 'string') {\n return Number(value)\n } else {\n return\n }\n}\n\n/**\n * `JSON.stringify` wrapper with custom replacer function that handles nested\n * BigInt and Uint8Array values.\n */\nexport function safeJsonStringify(obj: unknown): string {\n return JSON.stringify(obj, (_key, val) => {\n if (typeof val === 'bigint') {\n return val.toString()\n } else if (ArrayBuffer.isView(val)) {\n return Buffer.from(val.buffer, val.byteOffset, val.byteLength).toString('base64')\n }\n return val\n })\n}\n", "import { Error as ErrorObject } from './types'\n\nexport class DriverAdapterError extends Error {\n name = 'DriverAdapterError'\n cause: ErrorObject\n\n constructor(payload: ErrorObject) {\n super(typeof payload['message'] === 'string' ? payload['message'] : payload.kind)\n this.cause = payload\n }\n}\n\nexport function isDriverAdapterError(error: any): error is DriverAdapterError {\n return error['name'] === 'DriverAdapterError' && typeof error['cause'] === 'object'\n}\n", "// Same order as in rust driver-adapters' `ColumnType`.\n// Note: exporting const enums causes lots of problems with bundlers, so we emulate\n// them via regular dictionaries.\n// See: https://hackmd.io/@dzearing/Sk3xV0cLs\nexport const ColumnTypeEnum = {\n // Scalars\n Int32: 0,\n Int64: 1,\n Float: 2,\n Double: 3,\n Numeric: 4,\n Boolean: 5,\n Character: 6,\n Text: 7,\n Date: 8,\n Time: 9,\n DateTime: 10,\n Json: 11,\n Enum: 12,\n Bytes: 13,\n Set: 14,\n Uuid: 15,\n\n // Arrays\n Int32Array: 64,\n Int64Array: 65,\n FloatArray: 66,\n DoubleArray: 67,\n NumericArray: 68,\n BooleanArray: 69,\n CharacterArray: 70,\n TextArray: 71,\n DateArray: 72,\n TimeArray: 73,\n DateTimeArray: 74,\n JsonArray: 75,\n EnumArray: 76,\n BytesArray: 77,\n UuidArray: 78,\n\n // Custom\n UnknownNumber: 128,\n} as const\n", "import { DriverAdapterError, isDriverAdapterError } from '@prisma/driver-adapter-utils'\n\nimport { assertNever } from './utils'\n\nexport class UserFacingError extends Error {\n name = 'UserFacingError'\n code: string\n meta: Record<string, unknown>\n\n constructor(message: string, code: string, meta?: Record<string, unknown>) {\n super(message)\n this.code = code\n this.meta = meta ?? {}\n }\n\n toQueryResponseErrorObject() {\n return {\n error: this.message,\n user_facing_error: {\n is_panic: false,\n message: this.message,\n meta: this.meta,\n error_code: this.code,\n },\n }\n }\n}\n\nexport function rethrowAsUserFacing(error: any): never {\n if (!isDriverAdapterError(error)) {\n throw error\n }\n\n const code = getErrorCode(error)\n const message = renderErrorMessage(error)\n if (!code || !message) {\n throw error\n }\n throw new UserFacingError(message, code, { driverAdapterError: error })\n}\n\nexport function rethrowAsUserFacingRawError(error: any): never {\n if (!isDriverAdapterError(error)) {\n throw error\n }\n\n throw new UserFacingError(\n `Raw query failed. Code: \\`${error.cause.originalCode ?? 'N/A'}\\`. Message: \\`${\n error.cause.originalMessage ?? renderErrorMessage(error)\n }\\``,\n 'P2010',\n { driverAdapterError: error },\n )\n}\n\nfunction getErrorCode(err: DriverAdapterError): string | undefined {\n switch (err.cause.kind) {\n case 'AuthenticationFailed':\n return 'P1000'\n case 'DatabaseNotReachable':\n return 'P1001'\n case 'DatabaseDoesNotExist':\n return 'P1003'\n case 'SocketTimeout':\n return 'P1008'\n case 'DatabaseAlreadyExists':\n return 'P1009'\n case 'DatabaseAccessDenied':\n return 'P1010'\n case 'TlsConnectionError':\n return 'P1011'\n case 'ConnectionClosed':\n return 'P1017'\n case 'TransactionAlreadyClosed':\n return 'P1018'\n case 'LengthMismatch':\n return 'P2000'\n case 'UniqueConstraintViolation':\n return 'P2002'\n case 'ForeignKeyConstraintViolation':\n return 'P2003'\n case 'InvalidInputValue':\n return 'P2007'\n case 'UnsupportedNativeDataType':\n return 'P2010'\n case 'NullConstraintViolation':\n return 'P2011'\n case 'ValueOutOfRange':\n return 'P2020'\n case 'TableDoesNotExist':\n return 'P2021'\n case 'ColumnNotFound':\n return 'P2022'\n case 'InvalidIsolationLevel':\n case 'InconsistentColumnData':\n return 'P2023'\n case 'MissingFullTextSearchIndex':\n return 'P2030'\n case 'TransactionWriteConflict':\n return 'P2034'\n case 'GenericJs':\n return 'P2036'\n case 'TooManyConnections':\n return 'P2037'\n case 'postgres':\n case 'sqlite':\n case 'mysql':\n case 'mssql':\n return\n default:\n assertNever(err.cause, `Unknown error: ${err.cause}`)\n }\n}\n\nfunction renderErrorMessage(err: DriverAdapterError): string | undefined {\n switch (err.cause.kind) {\n case 'AuthenticationFailed': {\n const user = err.cause.user ?? '(not available)'\n return `Authentication failed against the database server, the provided database credentials for \\`${user}\\` are not valid`\n }\n case 'DatabaseNotReachable': {\n const address = err.cause.host && err.cause.port ? `${err.cause.host}:${err.cause.port}` : err.cause.host\n return `Can't reach database server${address ? ` at ${address}` : ''}`\n }\n case 'DatabaseDoesNotExist': {\n const db = err.cause.db ?? '(not available)'\n return `Database \\`${db}\\` does not exist on the database server`\n }\n case 'SocketTimeout':\n return `Operation has timed out`\n case 'DatabaseAlreadyExists': {\n const db = err.cause.db ?? '(not available)'\n return `Database \\`${db}\\` already exists on the database server`\n }\n case 'DatabaseAccessDenied': {\n const db = err.cause.db ?? '(not available)'\n return `User was denied access on the database \\`${db}\\``\n }\n case 'TlsConnectionError': {\n return `Error opening a TLS connection: ${err.cause.reason}`\n }\n case 'ConnectionClosed': {\n return 'Server has closed the connection.'\n }\n case 'TransactionAlreadyClosed':\n return err.cause.cause\n case 'LengthMismatch': {\n const column = err.cause.column ?? '(not available)'\n return `The provided value for the column is too long for the column's type. Column: ${column}`\n }\n case 'UniqueConstraintViolation':\n return `Unique constraint failed on the ${renderConstraint(err.cause.constraint)}`\n case 'ForeignKeyConstraintViolation':\n return `Foreign key constraint violated on the ${renderConstraint(err.cause.constraint)}`\n case 'UnsupportedNativeDataType':\n return `Failed to deserialize column of type '${err.cause.type}'. If you're using $queryRaw and this column is explicitly marked as \\`Unsupported\\` in your Prisma schema, try casting this column to any supported Prisma type such as \\`String\\`.`\n case 'NullConstraintViolation':\n return `Null constraint violation on the ${renderConstraint(err.cause.constraint)}`\n case 'ValueOutOfRange':\n return `Value out of range for the type: ${err.cause.cause}`\n case 'TableDoesNotExist': {\n const table = err.cause.table ?? '(not available)'\n return `The table \\`${table}\\` does not exist in the current database.`\n }\n case 'ColumnNotFound': {\n const column = err.cause.column ?? '(not available)'\n return `The column \\`${column}\\` does not exist in the current database.`\n }\n case 'InvalidIsolationLevel':\n return `Error in connector: Conversion error: ${err.cause.level}`\n case 'InconsistentColumnData':\n return `Inconsistent column data: ${err.cause.cause}`\n case 'MissingFullTextSearchIndex':\n return 'Cannot find a fulltext index to use for the native search, try adding a @@fulltext([Fields...]) to your schema'\n case 'TransactionWriteConflict':\n return `Transaction failed due to a write conflict or a deadlock. Please retry your transaction`\n case 'GenericJs':\n return `Error in external connector (id ${err.cause.id})`\n case 'TooManyConnections':\n return `Too many database connections opened: ${err.cause.cause}`\n case 'InvalidInputValue':\n return `Invalid input value: ${err.cause.message}`\n case 'sqlite':\n case 'postgres':\n case 'mysql':\n case 'mssql':\n return\n default:\n assertNever(err.cause, `Unknown error: ${err.cause}`)\n }\n}\n\nfunction renderConstraint(constraint?: { fields: string[] } | { index: string } | { foreignKey: {} }): string {\n if (constraint && 'fields' in constraint) {\n return `fields: (${constraint.fields.map((field) => `\\`${field}\\``).join(', ')})`\n } else if (constraint && 'index' in constraint) {\n return `constraint: \\`${constraint.index}\\``\n } else if (constraint && 'foreignKey' in constraint) {\n return `foreign key`\n }\n return '(not available)'\n}\n", "import { deserializeJsonResponse } from './json-protocol'\nimport { QueryPlanNode } from './query-plan'\nimport { UserFacingError } from './user-facing-error'\nimport { doKeysMatch } from './utils'\n\nexport type BatchResponse = MultiBatchResponse | CompactedBatchResponse\n\nexport type MultiBatchResponse = {\n type: 'multi'\n plans: QueryPlanNode[]\n}\n\nexport type CompactedBatchResponse = {\n type: 'compacted'\n plan: QueryPlanNode\n arguments: Record<string, {}>[]\n nestedSelection: string[]\n keys: string[]\n expectNonEmpty: boolean\n}\n\n/**\n * Checks if a value is a placeholder.\n * Handles both formats: `{ $type: 'Param', value: { name: '...' } }` and `{ prisma__type: 'param', prisma__value: { name: '...' } }`\n */\nfunction isPlaceholder(\n value: unknown,\n): value is { $type: 'Param'; value: { name: string } } | { prisma__type: 'param'; prisma__value: { name: string } } {\n if (typeof value !== 'object' || value === null) {\n return false\n }\n const obj = value as Record<string, unknown>\n // Check for JSON protocol format: { $type: 'Param', value: { name: '...' } }\n if ('$type' in obj && obj.$type === 'Param') {\n return true\n }\n // Check for serialized ArgumentValue format: { prisma__type: 'param', prisma__value: { name: '...' } }\n if ('prisma__type' in obj && obj.prisma__type === 'param') {\n return true\n }\n return false\n}\n\n/**\n * Extracts the placeholder name from a placeholder value.\n */\nfunction getPlaceholderName(\n value: { $type: 'Param'; value: { name: string } } | { prisma__type: 'param'; prisma__value: { name: string } },\n): string | undefined {\n if ('prisma__type' in value) {\n return value.prisma__value?.name\n }\n return (value as { value: { name: string } }).value.name\n}\n\n/**\n * Resolves placeholders in an argument object using the provided placeholder values.\n */\nfunction resolveArgPlaceholders(\n args: Record<string, {}>,\n placeholderValues: Record<string, unknown>,\n): Record<string, {}> {\n const resolved: Record<string, {}> = {}\n for (const [key, value] of Object.entries(args)) {\n resolved[key] = value\n if (isPlaceholder(value)) {\n const placeholderName = getPlaceholderName(value)\n if (placeholderName && placeholderName in placeholderValues) {\n resolved[key] = placeholderValues[placeholderName] as {}\n }\n }\n }\n return resolved\n}\n\n/**\n * Converts the result of a compacted query back to result objects analogous to what queries\n * would return when executed individually.\n */\nexport function convertCompactedRows(\n rows: {}[],\n compiledBatch: CompactedBatchResponse,\n placeholderValues: Record<string, unknown> = {},\n): unknown[] {\n // a list of objects that contain the keys of every row\n const keysPerRow = rows.map((item) =>\n compiledBatch.keys.reduce((acc, key) => {\n acc[key] = deserializeJsonResponse(item[key])\n return acc\n }, {}),\n )\n\n // the selections inferred from the request, used to filter unwanted columns from the results\n const selection = new Set(compiledBatch.nestedSelection)\n\n return compiledBatch.arguments.map((args) => {\n // Resolve any placeholders in the args using the provided placeholder values\n const resolvedArgs = resolveArgPlaceholders(args, placeholderValues)\n\n // we find the index of the row that matches the input arguments - this is the row we want\n // to return minus any extra columns not present in the selection\n const rowIndex = keysPerRow.findIndex((rowKeys) => doKeysMatch(rowKeys, resolvedArgs))\n if (rowIndex === -1) {\n if (compiledBatch.expectNonEmpty) {\n return new UserFacingError(\n 'An operation failed because it depends on one or more records that were required but not found',\n 'P2025',\n )\n } else {\n return null\n }\n } else {\n const selected = Object.entries(rows[rowIndex]).filter(([k]) => selection.has(k))\n return Object.fromEntries(selected)\n }\n })\n}\n", "import { Decimal } from '@prisma/client-runtime-utils'\n\nimport { FieldScalarType, FieldType, ResultNode } from '../query-plan'\nimport { UserFacingError } from '../user-facing-error'\nimport { assertNever, safeJsonStringify } from '../utils'\nimport { PrismaObject, Value } from './scope'\n\nexport class DataMapperError extends UserFacingError {\n name = 'DataMapperError'\n\n constructor(message: string, options?: { cause?: unknown }) {\n super(message, 'P2023', options)\n }\n}\n\n// Optimization: Cache field entries to avoid repeated Object.entries() allocations per row\nconst fieldEntriesCache = new WeakMap<Record<string, ResultNode>, [string, ResultNode][]>()\n\nfunction getFieldEntries(fields: Record<string, ResultNode>): [string, ResultNode][] {\n let entries = fieldEntriesCache.get(fields)\n if (!entries) {\n entries = Object.entries(fields)\n fieldEntriesCache.set(fields, entries)\n }\n return entries\n}\n\nexport function applyDataMap(data: Value, structure: ResultNode, enums: Record<string, Record<string, string>>): Value {\n switch (structure.type) {\n case 'affectedRows':\n if (typeof data !== 'number') {\n throw new DataMapperError(`Expected an affected rows count, got: ${typeof data} (${data})`)\n }\n return { count: data }\n\n case 'object':\n return mapArrayOrObject(data, structure.fields, enums, structure.skipNulls)\n\n case 'field':\n return mapValue(data, '<result>', structure.fieldType, enums)\n\n default:\n assertNever(structure, `Invalid data mapping type: '${(structure as ResultNode).type}'`)\n }\n}\n\nfunction mapArrayOrObject(\n data: Value,\n fields: Record<string, ResultNode>,\n enums: Record<string, Record<string, string>>,\n skipNulls?: boolean,\n): PrismaObject | PrismaObject[] | null {\n if (data === null) return null\n\n if (Array.isArray(data)) {\n let rows = data as PrismaObject[]\n if (skipNulls) {\n rows = rows.filter((row) => row !== null)\n }\n return rows.map((row) => mapObject(row, fields, enums))\n }\n\n if (typeof data === 'object') {\n const row = data as PrismaObject\n return mapObject(row, fields, enums)\n }\n\n if (typeof data === 'string') {\n let decodedData: Value\n try {\n decodedData = JSON.parse(data)\n } catch (error) {\n throw new DataMapperError(`Expected an array or object, got a string that is not valid JSON`, {\n cause: error,\n })\n }\n return mapArrayOrObject(decodedData, fields, enums, skipNulls)\n }\n\n throw new DataMapperError(`Expected an array or an object, got: ${typeof data}`)\n}\n\n// Recursive\nfunction mapObject(\n data: PrismaObject,\n fields: Record<string, ResultNode>,\n enums: Record<string, Record<string, string>>,\n): PrismaObject {\n if (typeof data !== 'object') {\n throw new DataMapperError(`Expected an object, but got '${typeof data}'`)\n }\n\n const result = {}\n for (const [name, node] of getFieldEntries(fields)) {\n switch (node.type) {\n case 'affectedRows': {\n throw new DataMapperError(`Unexpected 'AffectedRows' node in data mapping for field '${name}'`)\n }\n\n case 'object': {\n const { serializedName, fields: nodeFields, skipNulls } = node\n if (serializedName !== null && !Object.hasOwn(data, serializedName)) {\n throw new DataMapperError(\n `Missing data field (Object): '${name}'; ` + `node: ${JSON.stringify(node)}; data: ${JSON.stringify(data)}`,\n )\n }\n\n const target = serializedName !== null ? data[serializedName] : data\n result[name] = mapArrayOrObject(target, nodeFields, enums, skipNulls)\n break\n }\n\n case 'field':\n {\n const dbName = node.dbName\n if (Object.hasOwn(data, dbName)) {\n result[name] = mapField(data[dbName], dbName, node.fieldType, enums)\n } else {\n throw new DataMapperError(\n `Missing data field (Value): '${dbName}'; ` +\n `node: ${JSON.stringify(node)}; data: ${JSON.stringify(data)}`,\n )\n }\n }\n break\n\n default:\n assertNever(node, `DataMapper: Invalid data mapping node type: '${(node as ResultNode).type}'`)\n }\n }\n return result\n}\n\nfunction mapField(\n value: unknown,\n columnName: string,\n fieldType: FieldType,\n enums: Record<string, Record<string, string>>,\n): unknown {\n if (value === null) {\n return fieldType.arity === 'list' ? [] : null\n }\n\n if (fieldType.arity === 'list') {\n const values = value as unknown[]\n return values.map((v, i) => mapValue(v, `${columnName}[${i}]`, fieldType, enums))\n }\n\n return mapValue(value, columnName, fieldType, enums)\n}\n\nfunction mapValue(\n value: unknown,\n columnName: string,\n scalarType: FieldScalarType,\n enums: Record<string, Record<string, string>>,\n): unknown {\n switch (scalarType.type) {\n case 'unsupported':\n return value\n\n case 'string': {\n if (typeof value !== 'string') {\n throw new DataMapperError(`Expected a string in column '${columnName}', got ${typeof value}: ${value}`)\n }\n return value\n }\n\n case 'int': {\n switch (typeof value) {\n case 'number': {\n return Math.trunc(value)\n }\n\n case 'string': {\n const numberValue = Math.trunc(Number(value))\n if (Number.isNaN(numberValue) || !Number.isFinite(numberValue)) {\n throw new DataMapperError(`Expected an integer in column '${columnName}', got string: ${value}`)\n }\n if (!Number.isSafeInteger(numberValue)) {\n throw new DataMapperError(\n `Integer value in column '${columnName}' is too large to represent as a JavaScript number without loss of precision, got: ${value}. Consider using BigInt type.`,\n )\n }\n return numberValue\n }\n\n default:\n throw new DataMapperError(`Expected an integer in column '${columnName}', got ${typeof value}: ${value}`)\n }\n }\n\n case 'bigint': {\n if (typeof value !== 'number' && typeof value !== 'string') {\n throw new DataMapperError(`Expected a bigint in column '${columnName}', got ${typeof value}: ${value}`)\n }\n return { $type: 'BigInt', value }\n }\n\n case 'float': {\n if (typeof value === 'number') return value\n if (typeof value === 'string') {\n const parsedValue = Number(value)\n if (Number.isNaN(parsedValue) && !/^[-+]?nan$/.test(value.toLowerCase())) {\n throw new DataMapperError(`Expected a float in column '${columnName}', got string: ${value}`)\n }\n return parsedValue\n }\n throw new DataMapperError(`Expected a float in column '${columnName}', got ${typeof value}: ${value}`)\n }\n\n case 'boolean': {\n if (typeof value === 'boolean') return value\n if (typeof value === 'number') return value === 1\n if (typeof value === 'string') {\n if (value === 'true' || value === 'TRUE' || value === '1') {\n return true\n } else if (value === 'false' || value === 'FALSE' || value === '0') {\n return false\n } else {\n throw new DataMapperError(`Expected a boolean in column '${columnName}', got ${typeof value}: ${value}`)\n }\n }\n if (Array.isArray(value) || value instanceof Uint8Array) {\n for (const byte of value) {\n if (byte !== 0) return true\n }\n return false\n }\n throw new DataMapperError(`Expected a boolean in column '${columnName}', got ${typeof value}: ${value}`)\n }\n\n case 'decimal':\n if (typeof value !== 'number' && typeof value !== 'string' && !Decimal.isDecimal(value)) {\n throw new DataMapperError(`Expected a decimal in column '${columnName}', got ${typeof value}: ${value}`)\n }\n return { $type: 'Decimal', value }\n\n case 'datetime': {\n if (typeof value === 'string') {\n return { $type: 'DateTime', value: normalizeDateTime(value) }\n }\n if (typeof value === 'number' || value instanceof Date) {\n return { $type: 'DateTime', value }\n }\n throw new DataMapperError(`Expected a date in column '${columnName}', got ${typeof value}: ${value}`)\n }\n\n case 'object': {\n return { $type: 'Json', value: safeJsonStringify(value) }\n }\n\n case 'json': {\n // The value received here should normally be a string, but we cannot guarantee that,\n // because of SQLite databases like D1, which can return JSON scalars directly. We therefore\n // convert the value we receive to a string.\n return { $type: 'Json', value: `${value}` }\n }\n\n case 'bytes': {\n switch (scalarType.encoding) {\n case 'base64':\n if (typeof value !== 'string') {\n throw new DataMapperError(\n `Expected a base64-encoded byte array in column '${columnName}', got ${typeof value}: ${value}`,\n )\n }\n return { $type: 'Bytes', value }\n\n case 'hex':\n if (typeof value !== 'string' || !value.startsWith('\\\\x')) {\n throw new DataMapperError(\n `Expected a hex-encoded byte array in column '${columnName}', got ${typeof value}: ${value}`,\n )\n }\n return { $type: 'Bytes', value: Buffer.from(value.slice(2), 'hex').toString('base64') }\n\n case 'array':\n if (Array.isArray(value)) {\n return { $type: 'Bytes', value: Buffer.from(value).toString('base64') }\n }\n if (value instanceof Uint8Array) {\n return { $type: 'Bytes', value: Buffer.from(value).toString('base64') }\n }\n throw new DataMapperError(`Expected a byte array in column '${columnName}', got ${typeof value}: ${value}`)\n\n default:\n assertNever(scalarType.encoding, `DataMapper: Unknown bytes encoding: ${scalarType.encoding}`)\n }\n break\n }\n\n case 'enum': {\n const enumDef = enums[scalarType.name]\n if (enumDef === undefined) {\n throw new DataMapperError(`Unknown enum '${scalarType.name}'`)\n }\n const enumValue = enumDef[`${value}`]\n if (enumValue === undefined) {\n throw new DataMapperError(`Value '${value}' not found in enum '${scalarType.name}'`)\n }\n return enumValue\n }\n\n default:\n assertNever(scalarType, `DataMapper: Unknown result type: ${scalarType['type']}`)\n }\n}\n\n/**\n * A regular expression that matches a time string with an optional timezone.\n * It matches formats like:\n * - `12:34:56`\n * - `12:34:56.789`\n * - `12:34:56Z`\n * - `12:34:56+02`\n * - `12:34:56-02:30`\n */\nconst TIME_TZ_PATTERN = /\\d{2}:\\d{2}:\\d{2}(?:\\.\\d+)?(Z|[+-]\\d{2}(:?\\d{2})?)?$/\n\n/**\n * Normalizes date time strings received from driver adapters. The returned string is always a\n * valid input for the Javascript `Date` constructor. This function will add a UTC timezone suffix\n * if there's no timezone specified, to prevent it from being interpreted as local time.\n */\nfunction normalizeDateTime(dt: string): string {\n const timeTzMatches = TIME_TZ_PATTERN.exec(dt)\n if (timeTzMatches === null) {\n // We found no time part, so we return it as a plain zulu date,\n // e.g. '2023-10-01T00:00Z'.\n // We append the time because the JS Date constructor can't parse\n // pre-1000 dates with a timezone, for example '0032-01-01Z' parses\n // as '2032-01-01T00:00:00.000Z'.\n return `${dt}T00:00:00Z`\n }\n\n let dtWithTz = dt\n const [timeTz, tz, tzMinuteOffset] = timeTzMatches\n if (tz !== undefined && tz !== 'Z' && tzMinuteOffset === undefined) {\n // If the timezone is specified as +HH or -HH (without minutes),\n // we need to suffix it with ':00' to make it a valid Date input.\n dtWithTz = `${dt}:00`\n } else if (tz === undefined) {\n // If the timezone is not specified at all, we suffix it with 'Z'.\n dtWithTz = `${dt}Z`\n }\n\n if (timeTz.length === dt.length) {\n // If the entire datetime was just the time, we prepend the unix epoch date.\n return `1970-01-01T${dtWithTz}`\n }\n\n const timeSeparatorIndex = timeTzMatches.index - 1\n // If the time part is preceded by a space, we replace it with 'T'.\n if (dtWithTz[timeSeparatorIndex] === ' ') {\n dtWithTz = `${dtWithTz.slice(0, timeSeparatorIndex)}T${dtWithTz.slice(timeSeparatorIndex + 1)}`\n }\n\n return dtWithTz\n}\n", "export function klona(x) {\n\tif (typeof x !== 'object') return x;\n\n\tvar k, tmp, str=Object.prototype.toString.call(x);\n\n\tif (str === '[object Object]') {\n\t\tif (x.constructor !== Object && typeof x.constructor === 'function') {\n\t\t\ttmp = new x.constructor();\n\t\t\tfor (k in x) {\n\t\t\t\tif (x.hasOwnProperty(k) && tmp[k] !== x[k]) {\n\t\t\t\t\ttmp[k] = klona(x[k]);\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\ttmp = {}; // null\n\t\t\tfor (k in x) {\n\t\t\t\tif (k === '__proto__') {\n\t\t\t\t\tObject.defineProperty(tmp, k, {\n\t\t\t\t\t\tvalue: klona(x[k]),\n\t\t\t\t\t\tconfigurable: true,\n\t\t\t\t\t\tenumerable: true,\n\t\t\t\t\t\twritable: true,\n\t\t\t\t\t});\n\t\t\t\t} else {\n\t\t\t\t\ttmp[k] = klona(x[k]);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn tmp;\n\t}\n\n\tif (str === '[object Array]') {\n\t\tk = x.length;\n\t\tfor (tmp=Array(k); k--;) {\n\t\t\ttmp[k] = klona(x[k]);\n\t\t}\n\t\treturn tmp;\n\t}\n\n\tif (str === '[object Set]') {\n\t\ttmp = new Set;\n\t\tx.forEach(function (val) {\n\t\t\ttmp.add(klona(val));\n\t\t});\n\t\treturn tmp;\n\t}\n\n\tif (str === '[object Map]') {\n\t\ttmp = new Map;\n\t\tx.forEach(function (val, key) {\n\t\t\ttmp.set(klona(key), klona(val));\n\t\t});\n\t\treturn tmp;\n\t}\n\n\tif (str === '[object Date]') {\n\t\treturn new Date(+x);\n\t}\n\n\tif (str === '[object RegExp]') {\n\t\ttmp = new RegExp(x.source, x.flags);\n\t\ttmp.lastIndex = x.lastIndex;\n\t\treturn tmp;\n\t}\n\n\tif (str === '[object DataView]') {\n\t\treturn new x.constructor( klona(x.buffer) );\n\t}\n\n\tif (str === '[object ArrayBuffer]') {\n\t\treturn x.slice(0);\n\t}\n\n\t// ArrayBuffer.isView(x)\n\t// ~> `new` bcuz `Buffer.slice` => ref\n\tif (str.slice(-6) === 'Array]') {\n\t\treturn new x.constructor(x);\n\t}\n\n\treturn x;\n}\n", "import type { SqlCommenterContext, SqlCommenterPlugin } from '@prisma/sqlcommenter'\nimport { klona } from 'klona'\n\n/**\n * Formats key-value pairs into a sqlcommenter-compatible comment string.\n *\n * Algorithm per https://google.github.io/sqlcommenter/spec/:\n * 1. If the map is empty, return empty string\n * 2. Sort keys lexicographically\n * 3. URL-encode keys\n * 4. URL-encode values\n * 5. Replace ' with \\' in values (after URL encoding)\n * 6. Wrap values in single quotes\n * 7. Join key='value' pairs with commas\n * 8. Wrap in a SQL comment\n */\nexport function formatSqlComment(tags: Record<string, string>): string {\n const entries = Object.entries(tags)\n if (entries.length === 0) {\n return ''\n }\n\n // Sort by key lexicographically\n entries.sort(([a], [b]) => a.localeCompare(b))\n\n const parts = entries.map(([key, value]) => {\n const encodedKey = encodeURIComponent(key)\n const encodedValue = encodeURIComponent(value).replace(/'/g, \"\\\\'\")\n return `${encodedKey}='${encodedValue}'`\n })\n\n return `/*${parts.join(',')}*/`\n}\n\n/**\n * Applies SQL commenter plugins and returns the merged key-value pairs.\n * Keys with undefined values are filtered out.\n *\n * Each plugin receives a deep clone of the context to prevent mutations\n * that could affect other plugins.\n */\nexport function applySqlCommenters(\n plugins: SqlCommenterPlugin[],\n context: SqlCommenterContext,\n): Record<string, string> {\n const merged: Record<string, string> = {}\n\n for (const plugin of plugins) {\n const tags = plugin(klona(context))\n for (const [key, value] of Object.entries(tags)) {\n if (value !== undefined) {\n merged[key] = value\n }\n }\n }\n\n return merged\n}\n\n/**\n * Applies SQL commenter plugins and returns the formatted comment.\n */\nexport function buildSqlComment(plugins: SqlCommenterPlugin[], context: SqlCommenterContext): string {\n const tags = applySqlCommenters(plugins, context)\n return formatSqlComment(tags)\n}\n\n/**\n * Appends a sqlcommenter comment to a SQL query.\n */\nexport function appendSqlComment(sql: string, comment: string): string {\n if (!comment) {\n return sql\n }\n return `${sql} ${comment}`\n}\n", "/*\n * Copyright The OpenTelemetry Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nexport enum SpanKind {\n /** Default value. Indicates that the span is used internally. */\n INTERNAL = 0,\n\n /**\n * Indicates that the span covers server-side handling of an RPC or other\n * remote request.\n */\n SERVER = 1,\n\n /**\n * Indicates that the span covers the client-side wrapper around an RPC or\n * other remote request.\n */\n CLIENT = 2,\n\n /**\n * Indicates that the span describes producer sending a message to a\n * broker. Unlike client and server, there is no direct critical path latency\n * relationship between producer and consumer spans.\n */\n PRODUCER = 3,\n\n /**\n * Indicates that the span describes consumer receiving a message from a\n * broker. Unlike client and server, there is no direct critical path latency\n * relationship between producer and consumer spans.\n */\n CONSUMER = 4,\n}\n", "import { type Context, type Span, SpanKind, type SpanOptions } from '@opentelemetry/api'\nimport type { SqlQuery } from '@prisma/driver-adapter-utils'\n\nimport { QueryEvent } from './events'\nimport type { SchemaProvider } from './schema'\nimport { assertNever } from './utils'\n\nexport type SpanCallback<R> = (span?: Span, context?: Context) => R\n\nexport type ExtendedSpanOptions = SpanOptions & {\n name: string\n}\n\n// A smaller version of the equivalent interface from `@prisma/internals`\nexport interface TracingHelper {\n isEnabled(): boolean\n runInChildSpan<R>(nameOrOptions: string | ExtendedSpanOptions, callback: SpanCallback<R>): R\n}\n\nexport const noopTracingHelper: TracingHelper = {\n isEnabled() {\n return false\n },\n runInChildSpan(_, callback) {\n return callback()\n },\n}\n\nexport function providerToOtelSystem(provider: SchemaProvider): string {\n switch (provider) {\n case 'postgresql':\n case 'postgres':\n case 'prisma+postgres':\n return 'postgresql'\n case 'sqlserver':\n return 'mssql'\n case 'mysql':\n case 'sqlite':\n case 'cockroachdb':\n case 'mongodb':\n return provider\n default:\n assertNever(provider, `Unknown provider: ${provider}`)\n }\n}\n\nexport async function withQuerySpanAndEvent<T>({\n query,\n tracingHelper,\n provider,\n onQuery,\n execute,\n}: {\n query: SqlQuery\n tracingHelper: TracingHelper\n provider: SchemaProvider\n onQuery?: (event: QueryEvent) => void\n execute: () => Promise<T>\n}): Promise<T> {\n const callback =\n onQuery === undefined\n ? execute\n : async () => {\n const timestamp = new Date()\n const startInstant = performance.now()\n const result = await execute()\n const endInstant = performance.now()\n\n onQuery({\n timestamp,\n duration: endInstant - startInstant,\n query: query.sql,\n params: query.args,\n })\n\n return result\n }\n\n if (!tracingHelper.isEnabled()) {\n return callback()\n }\n\n return await tracingHelper.runInChildSpan(\n {\n name: 'db_query',\n kind: SpanKind.CLIENT,\n attributes: {\n 'db.query.text': query.sql,\n 'db.system.name': providerToOtelSystem(provider),\n },\n },\n callback,\n )\n}\n", "export default function pad (num, size) {\n var s = '000000000' + num;\n return s.substr(s.length - size);\n}\n", "import pad from './pad.mjs';\nimport os from 'os';\n\nfunction getHostname () {\n try {\n return os.hostname();\n } catch (e) {\n /**\n * This is most likely Windows 7 which is known to cause os.hostname() to break\n * @see https://github.com/nodejs/node/issues/41297\n * @see https://github.com/libuv/libuv/issues/3260\n *\n * Fallback to take hostname from environment variables\n * @see https://docs.microsoft.com/en-us/windows-server/administration/windows-commands/hostname#notes\n */\n // eslint-disable-next-line no-underscore-dangle\n return process.env._CLUSTER_NETWORK_NAME_ || process.env.COMPUTERNAME || 'hostname';\n }\n}\n\nvar padding = 2,\n pid = pad(process.pid.toString(36), padding),\n hostname = getHostname(),\n length = hostname.length,\n hostId = pad(hostname\n .split('')\n .reduce(function (prev, char) {\n return +prev + char.charCodeAt(0);\n }, +length + 36)\n .toString(36),\n padding);\n\nexport default function fingerprint () {\n return pid + hostId;\n}\n", "/**\n * Check the provided value is a valid device id\n * @param {unknown} value\n * @returns\n */\nexport default function isCuid (value) {\n return typeof value === 'string' && (/^c[a-z0-9]{20,32}$/).test(value);\n}\n", "/**\n * cuid.js\n * Collision-resistant UID generator for browsers and node.\n * Sequential for fast db lookups and recency sorting.\n * Safe for element IDs and server-side lookups.\n *\n * Extracted from CLCTR\n *\n * Copyright (c) Eric Elliott 2012\n * MIT License\n */\n\nimport isCuid from './is-cuid.mjs';\nimport pad from './pad.mjs';\n\nexport default function createCuid (fingerprint) {\n const blockSize = 4,\n base = 36,\n discreteValues = Math.pow(base, blockSize);\n\n let c = 0;\n\n function randomBlock () {\n return pad((Math.random() *\n discreteValues << 0)\n .toString(base), blockSize);\n }\n\n function safeCounter () {\n c = c < discreteValues ? c : 0;\n c++; // this is not subliminal\n return c - 1;\n }\n\n function cuid () {\n // Starting with a lowercase letter makes\n // it HTML element ID friendly.\n var letter = 'c', // hard-coded allows for sequential access\n\n // timestamp\n // warning: this exposes the exact date and time\n // that the uid was created.\n timestamp = new Date().getTime().toString(base),\n\n // Prevent same-machine collisions.\n counter = pad(safeCounter().toString(base), blockSize),\n\n // A few chars to generate distinct ids for different\n // clients (so different computers are far less\n // likely to generate the same id)\n print = fingerprint(),\n\n // Grab some more chars from Math.random()\n random = randomBlock() + randomBlock();\n\n return letter + timestamp + counter + print + random;\n }\n\n cuid.fingerprint = fingerprint;\n cuid.isCuid = isCuid;\n\n return cuid;\n}\n\n", "/**\n * cuid.js\n * Collision-resistant UID generator for browsers and node.\n * Sequential for fast db lookups and recency sorting.\n * Safe for element IDs and server-side lookups.\n *\n * Extracted from CLCTR\n *\n * Copyright (c) Eric Elliott 2012\n * MIT License\n */\n\nimport fingerprint from '#fingerprint';\nimport createCuid from './lib/cuid.mjs';\nimport isCuid from './lib/is-cuid.mjs';\n\nconst cuid = createCuid(fingerprint);\n\nexport { fingerprint, isCuid };\n\nexport default cuid;\n", "import cuid1 from '@bugsnag/cuid'\nimport { createId as cuid2 } from '@paralleldrive/cuid2'\nimport { nanoid } from 'nanoid'\nimport { ulid } from 'ulid'\nimport { v4 as uuidv4, v7 as uuidv7 } from 'uuid'\n\nexport class GeneratorRegistry {\n #generators: GeneratorRegistrySnapshot = {}\n\n constructor() {\n this.register('uuid', new UuidGenerator())\n this.register('cuid', new CuidGenerator())\n this.register('ulid', new UlidGenerator())\n this.register('nanoid', new NanoIdGenerator())\n this.register('product', new ProductGenerator())\n }\n\n /**\n * Returns a snapshot of the generator registry. It's 'frozen' in time at the moment of this\n * method being called, meaning that the built-in time-based generators will always return\n * the same value on repeated calls as long as the same snapshot is used.\n */\n snapshot(): Readonly<GeneratorRegistrySnapshot> {\n return Object.create(this.#generators, {\n now: {\n value: new NowGenerator(),\n },\n })\n }\n\n /**\n * Registers a new generator with the given name.\n */\n register(name: string, generator: ValueGenerator): void {\n this.#generators[name] = generator\n }\n}\n\nexport interface GeneratorRegistrySnapshot {\n [key: string]: ValueGenerator\n}\n\nexport interface ValueGenerator {\n generate(...args: unknown[]): unknown\n}\n\nclass NowGenerator implements ValueGenerator {\n #now: Date = new Date()\n\n generate(): string {\n return this.#now.toISOString()\n }\n}\n\nclass UuidGenerator implements ValueGenerator {\n generate(arg: unknown): string {\n if (arg === 4) {\n return uuidv4()\n } else if (arg === 7) {\n return uuidv7()\n } else {\n throw new Error('Invalid UUID generator arguments')\n }\n }\n}\n\nclass CuidGenerator implements ValueGenerator {\n generate(arg: unknown): string {\n if (arg === 1) {\n return cuid1()\n } else if (arg === 2) {\n return cuid2()\n } else {\n throw new Error('Invalid CUID generator arguments')\n }\n }\n}\n\nclass UlidGenerator implements ValueGenerator {\n generate(): string {\n return ulid()\n }\n}\n\nclass NanoIdGenerator implements ValueGenerator {\n generate(arg: unknown): string {\n if (typeof arg === 'number') {\n return nanoid(arg)\n } else if (arg === undefined) {\n return nanoid()\n } else {\n throw new Error('Invalid Nanoid generator arguments')\n }\n }\n}\n\nclass ProductGenerator implements ValueGenerator {\n generate(lhs: unknown, rhs: unknown): unknown[] {\n if (lhs === undefined || rhs === undefined) {\n throw new Error('Invalid Product generator arguments')\n }\n\n if (Array.isArray(lhs) && Array.isArray(rhs)) {\n return lhs.flatMap((l) => rhs.map((r) => [l, r]))\n } else if (Array.isArray(lhs)) {\n return lhs.map((l) => [l, rhs])\n } else if (Array.isArray(rhs)) {\n return rhs.map((r) => [lhs, r])\n } else {\n return [[lhs, rhs]]\n }\n }\n}\n", "import { webcrypto as crypto } from 'node:crypto'\nimport { urlAlphabet as scopedUrlAlphabet } from './url-alphabet/index.js'\nexport { urlAlphabet } from './url-alphabet/index.js'\nconst POOL_SIZE_MULTIPLIER = 128\nlet pool, poolOffset\nfunction fillPool(bytes) {\n if (!pool || pool.length < bytes) {\n pool = Buffer.allocUnsafe(bytes * POOL_SIZE_MULTIPLIER)\n crypto.getRandomValues(pool)\n poolOffset = 0\n } else if (poolOffset + bytes > pool.length) {\n crypto.getRandomValues(pool)\n poolOffset = 0\n }\n poolOffset += bytes\n}\nexport function random(bytes) {\n fillPool((bytes |= 0))\n return pool.subarray(poolOffset - bytes, poolOffset)\n}\nexport function customRandom(alphabet, defaultSize, getRandom) {\n let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1\n let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length)\n return (size = defaultSize) => {\n let id = ''\n while (true) {\n let bytes = getRandom(step)\n let i = step\n while (i--) {\n id += alphabet[bytes[i] & mask] || ''\n if (id.length >= size) return id\n }\n }\n }\n}\nexport function customAlphabet(alphabet, size = 21) {\n return customRandom(alphabet, size, random)\n}\nexport function nanoid(size = 21) {\n fillPool((size |= 0))\n let id = ''\n for (let i = poolOffset - size; i < poolOffset; i++) {\n id += scopedUrlAlphabet[pool[i] & 63]\n }\n return id\n}\n", "export const urlAlphabet =\n 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict'\n", "import crypto from 'node:crypto';\n\n// These values should NEVER change. The values are precisely for\n// generating ULIDs.\nconst B32_CHARACTERS = \"0123456789ABCDEFGHJKMNPQRSTVWXYZ\";\nconst ENCODING = \"0123456789ABCDEFGHJKMNPQRSTVWXYZ\"; // Crockford's Base32\nconst ENCODING_LEN = 32; // from ENCODING.length;\nconst MAX_ULID = \"7ZZZZZZZZZZZZZZZZZZZZZZZZZ\";\nconst MIN_ULID = \"00000000000000000000000000\";\nconst RANDOM_LEN = 16;\nconst TIME_LEN = 10;\nconst TIME_MAX = 281474976710655; // from Math.pow(2, 48) - 1;\nconst ULID_REGEX = /^[0-7][0-9a-hjkmnp-tv-zA-HJKMNP-TV-Z]{25}$/;\nconst UUID_REGEX = /^[0-9a-fA-F]{8}-(?:[0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}$/;\n\nvar ULIDErrorCode;\n(function (ULIDErrorCode) {\n ULIDErrorCode[\"Base32IncorrectEncoding\"] = \"B32_ENC_INVALID\";\n ULIDErrorCode[\"DecodeTimeInvalidCharacter\"] = \"DEC_TIME_CHAR\";\n ULIDErrorCode[\"DecodeTimeValueMalformed\"] = \"DEC_TIME_MALFORMED\";\n ULIDErrorCode[\"EncodeTimeNegative\"] = \"ENC_TIME_NEG\";\n ULIDErrorCode[\"EncodeTimeSizeExceeded\"] = \"ENC_TIME_SIZE_EXCEED\";\n ULIDErrorCode[\"EncodeTimeValueMalformed\"] = \"ENC_TIME_MALFORMED\";\n ULIDErrorCode[\"PRNGDetectFailure\"] = \"PRNG_DETECT\";\n ULIDErrorCode[\"ULIDInvalid\"] = \"ULID_INVALID\";\n ULIDErrorCode[\"Unexpected\"] = \"UNEXPECTED\";\n ULIDErrorCode[\"UUIDInvalid\"] = \"UUID_INVALID\";\n})(ULIDErrorCode || (ULIDErrorCode = {}));\nclass ULIDError extends Error {\n constructor(errorCode, message) {\n super(`${message} (${errorCode})`);\n this.name = \"ULIDError\";\n this.code = errorCode;\n }\n}\n\nfunction randomChar(prng) {\n let rand = Math.floor(prng() * ENCODING_LEN);\n if (rand === ENCODING_LEN) {\n rand = ENCODING_LEN - 1;\n }\n return ENCODING.charAt(rand);\n}\nfunction replaceCharAt(str, index, char) {\n if (index > str.length - 1) {\n return str;\n }\n return str.substr(0, index) + char + str.substr(index + 1);\n}\n\n// Code from https://github.com/devbanana/crockford-base32/blob/develop/src/index.ts\nfunction crockfordEncode(input) {\n const output = [];\n let bitsRead = 0;\n let buffer = 0;\n const reversedInput = new Uint8Array(input.slice().reverse());\n for (const byte of reversedInput) {\n buffer |= byte << bitsRead;\n bitsRead += 8;\n while (bitsRead >= 5) {\n output.unshift(buffer & 0x1f);\n buffer >>>= 5;\n bitsRead -= 5;\n }\n }\n if (bitsRead > 0) {\n output.unshift(buffer & 0x1f);\n }\n return output.map(byte => B32_CHARACTERS.charAt(byte)).join(\"\");\n}\nfunction crockfordDecode(input) {\n const sanitizedInput = input.toUpperCase().split(\"\").reverse().join(\"\");\n const output = [];\n let bitsRead = 0;\n let buffer = 0;\n for (const character of sanitizedInput) {\n const byte = B32_CHARACTERS.indexOf(character);\n if (byte === -1) {\n throw new Error(`Invalid base 32 character found in string: ${character}`);\n }\n buffer |= byte << bitsRead;\n bitsRead += 5;\n while (bitsRead >= 8) {\n output.unshift(buffer & 0xff);\n buffer >>>= 8;\n bitsRead -= 8;\n }\n }\n if (bitsRead >= 5 || buffer > 0) {\n output.unshift(buffer & 0xff);\n }\n return new Uint8Array(output);\n}\n/**\n * Fix a ULID's Base32 encoding -\n * i and l (case-insensitive) will be treated as 1 and o (case-insensitive) will be treated as 0.\n * hyphens are ignored during decoding.\n * @param id The ULID\n * @returns The cleaned up ULID\n */\nfunction fixULIDBase32(id) {\n return id.replace(/i/gi, \"1\").replace(/l/gi, \"1\").replace(/o/gi, \"0\").replace(/-/g, \"\");\n}\nfunction incrementBase32(str) {\n let done = undefined, index = str.length, char, charIndex, output = str;\n const maxCharIndex = ENCODING_LEN - 1;\n while (!done && index-- >= 0) {\n char = output[index];\n charIndex = ENCODING.indexOf(char);\n if (charIndex === -1) {\n throw new ULIDError(ULIDErrorCode.Base32IncorrectEncoding, \"Incorrectly encoded string\");\n }\n if (charIndex === maxCharIndex) {\n output = replaceCharAt(output, index, ENCODING[0]);\n continue;\n }\n done = replaceCharAt(output, index, ENCODING[charIndex + 1]);\n }\n if (typeof done === \"string\") {\n return done;\n }\n throw new ULIDError(ULIDErrorCode.Base32IncorrectEncoding, \"Failed incrementing string\");\n}\n\n/**\n * Decode time from a ULID\n * @param id The ULID\n * @returns The decoded timestamp\n */\nfunction decodeTime(id) {\n if (id.length !== TIME_LEN + RANDOM_LEN) {\n throw new ULIDError(ULIDErrorCode.DecodeTimeValueMalformed, \"Malformed ULID\");\n }\n const time = id\n .substr(0, TIME_LEN)\n .toUpperCase()\n .split(\"\")\n .reverse()\n .reduce((carry, char, index) => {\n const encodingIndex = ENCODING.indexOf(char);\n if (encodingIndex === -1) {\n throw new ULIDError(ULIDErrorCode.DecodeTimeInvalidCharacter, `Time decode error: Invalid character: ${char}`);\n }\n return (carry += encodingIndex * Math.pow(ENCODING_LEN, index));\n }, 0);\n if (time > TIME_MAX) {\n throw new ULIDError(ULIDErrorCode.DecodeTimeValueMalformed, `Malformed ULID: timestamp too large: ${time}`);\n }\n return time;\n}\n/**\n * Detect the best PRNG (pseudo-random number generator)\n * @param root The root to check from (global/window)\n * @returns The PRNG function\n */\nfunction detectPRNG(root) {\n const rootLookup = detectRoot();\n const globalCrypto = (rootLookup && (rootLookup.crypto || rootLookup.msCrypto)) ||\n (typeof crypto !== \"undefined\" ? crypto : null);\n if (typeof globalCrypto?.getRandomValues === \"function\") {\n return () => {\n const buffer = new Uint8Array(1);\n globalCrypto.getRandomValues(buffer);\n return buffer[0] / 0xff;\n };\n }\n else if (typeof globalCrypto?.randomBytes === \"function\") {\n return () => globalCrypto.randomBytes(1).readUInt8() / 0xff;\n }\n else if (crypto?.randomBytes) {\n return () => crypto.randomBytes(1).readUInt8() / 0xff;\n }\n throw new ULIDError(ULIDErrorCode.PRNGDetectFailure, \"Failed to find a reliable PRNG\");\n}\nfunction detectRoot() {\n if (inWebWorker())\n return self;\n if (typeof window !== \"undefined\") {\n return window;\n }\n if (typeof global !== \"undefined\") {\n return global;\n }\n if (typeof globalThis !== \"undefined\") {\n return globalThis;\n }\n return null;\n}\nfunction encodeRandom(len, prng) {\n let str = \"\";\n for (; len > 0; len--) {\n str = randomChar(prng) + str;\n }\n return str;\n}\n/**\n * Encode the time portion of a ULID\n * @param now The current timestamp\n * @param len Length to generate\n * @returns The encoded time\n */\nfunction encodeTime(now, len = TIME_LEN) {\n if (isNaN(now)) {\n throw new ULIDError(ULIDErrorCode.EncodeTimeValueMalformed, `Time must be a number: ${now}`);\n }\n else if (now > TIME_MAX) {\n throw new ULIDError(ULIDErrorCode.EncodeTimeSizeExceeded, `Cannot encode a time larger than ${TIME_MAX}: ${now}`);\n }\n else if (now < 0) {\n throw new ULIDError(ULIDErrorCode.EncodeTimeNegative, `Time must be positive: ${now}`);\n }\n else if (Number.isInteger(now) === false) {\n throw new ULIDError(ULIDErrorCode.EncodeTimeValueMalformed, `Time must be an integer: ${now}`);\n }\n let mod, str = \"\";\n for (let currentLen = len; currentLen > 0; currentLen--) {\n mod = now % ENCODING_LEN;\n str = ENCODING.charAt(mod) + str;\n now = (now - mod) / ENCODING_LEN;\n }\n return str;\n}\nfunction inWebWorker() {\n // @ts-ignore\n return typeof WorkerGlobalScope !== \"undefined\" && self instanceof WorkerGlobalScope;\n}\n/**\n * Check if a ULID is valid\n * @param id The ULID to test\n * @returns True if valid, false otherwise\n * @example\n * isValid(\"01HNZX8JGFACFA36RBXDHEQN6E\"); // true\n * isValid(\"\"); // false\n */\nfunction isValid(id) {\n return (typeof id === \"string\" &&\n id.length === TIME_LEN + RANDOM_LEN &&\n id\n .toUpperCase()\n .split(\"\")\n .every(char => ENCODING.indexOf(char) !== -1));\n}\n/**\n * Create a ULID factory to generate monotonically-increasing\n * ULIDs\n * @param prng The PRNG to use\n * @returns A ulid factory\n * @example\n * const ulid = monotonicFactory();\n * ulid(); // \"01HNZXD07M5CEN5XA66EMZSRZW\"\n */\nfunction monotonicFactory(prng) {\n const currentPRNG = prng || detectPRNG();\n let lastTime = 0, lastRandom;\n return function _ulid(seedTime) {\n const seed = !seedTime || isNaN(seedTime) ? Date.now() : seedTime;\n if (seed <= lastTime) {\n const incrementedRandom = (lastRandom = incrementBase32(lastRandom));\n return encodeTime(lastTime, TIME_LEN) + incrementedRandom;\n }\n lastTime = seed;\n const newRandom = (lastRandom = encodeRandom(RANDOM_LEN, currentPRNG));\n return encodeTime(seed, TIME_LEN) + newRandom;\n };\n}\n/**\n * Generate a ULID\n * @param seedTime Optional time seed\n * @param prng Optional PRNG function\n * @returns A ULID string\n * @example\n * ulid(); // \"01HNZXD07M5CEN5XA66EMZSRZW\"\n */\nfunction ulid(seedTime, prng) {\n const currentPRNG = prng || detectPRNG();\n const seed = !seedTime || isNaN(seedTime) ? Date.now() : seedTime;\n return encodeTime(seed, TIME_LEN) + encodeRandom(RANDOM_LEN, currentPRNG);\n}\n\n/**\n * Convert a ULID to a UUID\n * @param ulid The ULID to convert\n * @returns A UUID string\n */\nfunction ulidToUUID(ulid) {\n const isValid = ULID_REGEX.test(ulid);\n if (!isValid) {\n throw new ULIDError(ULIDErrorCode.ULIDInvalid, `Invalid ULID: ${ulid}`);\n }\n const uint8Array = crockfordDecode(ulid);\n let uuid = Array.from(uint8Array)\n .map(byte => byte.toString(16).padStart(2, \"0\"))\n .join(\"\");\n uuid =\n uuid.substring(0, 8) +\n \"-\" +\n uuid.substring(8, 12) +\n \"-\" +\n uuid.substring(12, 16) +\n \"-\" +\n uuid.substring(16, 20) +\n \"-\" +\n uuid.substring(20);\n return uuid.toUpperCase();\n}\n/**\n * Convert a UUID to a ULID\n * @param uuid The UUID to convert\n * @returns A ULID string\n */\nfunction uuidToULID(uuid) {\n const isValid = UUID_REGEX.test(uuid);\n if (!isValid) {\n throw new ULIDError(ULIDErrorCode.UUIDInvalid, `Invalid UUID: ${uuid}`);\n }\n const bytes = uuid.replace(/-/g, \"\").match(/.{1,2}/g);\n if (!bytes) {\n throw new ULIDError(ULIDErrorCode.Unexpected, `Failed parsing UUID bytes: ${uuid}`);\n }\n const uint8Array = new Uint8Array(bytes.map(byte => parseInt(byte, 16)));\n return crockfordEncode(uint8Array);\n}\n\nexport { MAX_ULID, MIN_ULID, TIME_LEN, TIME_MAX, ULIDError, ULIDErrorCode, decodeTime, encodeTime, fixULIDBase32, incrementBase32, isValid, monotonicFactory, ulid, ulidToUUID, uuidToULID };\n", "import validate from './validate.js';\nconst byteToHex = [];\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\nexport function unsafeStringify(arr, offset = 0) {\n return (byteToHex[arr[offset + 0]] +\n byteToHex[arr[offset + 1]] +\n byteToHex[arr[offset + 2]] +\n byteToHex[arr[offset + 3]] +\n '-' +\n byteToHex[arr[offset + 4]] +\n byteToHex[arr[offset + 5]] +\n '-' +\n byteToHex[arr[offset + 6]] +\n byteToHex[arr[offset + 7]] +\n '-' +\n byteToHex[arr[offset + 8]] +\n byteToHex[arr[offset + 9]] +\n '-' +\n byteToHex[arr[offset + 10]] +\n byteToHex[arr[offset + 11]] +\n byteToHex[arr[offset + 12]] +\n byteToHex[arr[offset + 13]] +\n byteToHex[arr[offset + 14]] +\n byteToHex[arr[offset + 15]]).toLowerCase();\n}\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset);\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n return uuid;\n}\nexport default stringify;\n", "import { randomFillSync } from 'crypto';\nconst rnds8Pool = new Uint8Array(256);\nlet poolPtr = rnds8Pool.length;\nexport default function rng() {\n if (poolPtr > rnds8Pool.length - 16) {\n randomFillSync(rnds8Pool);\n poolPtr = 0;\n }\n return rnds8Pool.slice(poolPtr, (poolPtr += 16));\n}\n", "import { randomUUID } from 'crypto';\nexport default { randomUUID };\n", "import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n options = options || {};\n const rnds = options.random ?? options.rng?.() ?? rng();\n if (rnds.length < 16) {\n throw new Error('Random bytes length must be >= 16');\n }\n rnds[6] = (rnds[6] & 0x0f) | 0x40;\n rnds[8] = (rnds[8] & 0x3f) | 0x80;\n if (buf) {\n offset = offset || 0;\n if (offset < 0 || offset + 16 > buf.length) {\n throw new RangeError(`UUID byte range ${offset}:${offset + 15} is out of buffer bounds`);\n }\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n return buf;\n }\n return unsafeStringify(rnds);\n}\nexport default v4;\n", "import rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\nconst _state = {};\nfunction v7(options, buf, offset) {\n let bytes;\n if (options) {\n bytes = v7Bytes(options.random ?? options.rng?.() ?? rng(), options.msecs, options.seq, buf, offset);\n }\n else {\n const now = Date.now();\n const rnds = rng();\n updateV7State(_state, now, rnds);\n bytes = v7Bytes(rnds, _state.msecs, _state.seq, buf, offset);\n }\n return buf ?? unsafeStringify(bytes);\n}\nexport function updateV7State(state, now, rnds) {\n state.msecs ??= -Infinity;\n state.seq ??= 0;\n if (now > state.msecs) {\n state.seq = (rnds[6] << 23) | (rnds[7] << 16) | (rnds[8] << 8) | rnds[9];\n state.msecs = now;\n }\n else {\n state.seq = (state.seq + 1) | 0;\n if (state.seq === 0) {\n state.msecs++;\n }\n }\n return state;\n}\nfunction v7Bytes(rnds, msecs, seq, buf, offset = 0) {\n if (rnds.length < 16) {\n throw new Error('Random bytes length must be >= 16');\n }\n if (!buf) {\n buf = new Uint8Array(16);\n offset = 0;\n }\n else {\n if (offset < 0 || offset + 16 > buf.length) {\n throw new RangeError(`UUID byte range ${offset}:${offset + 15} is out of buffer bounds`);\n }\n }\n msecs ??= Date.now();\n seq ??= ((rnds[6] * 0x7f) << 24) | (rnds[7] << 16) | (rnds[8] << 8) | rnds[9];\n buf[offset++] = (msecs / 0x10000000000) & 0xff;\n buf[offset++] = (msecs / 0x100000000) & 0xff;\n buf[offset++] = (msecs / 0x1000000) & 0xff;\n buf[offset++] = (msecs / 0x10000) & 0xff;\n buf[offset++] = (msecs / 0x100) & 0xff;\n buf[offset++] = msecs & 0xff;\n buf[offset++] = 0x70 | ((seq >>> 28) & 0x0f);\n buf[offset++] = (seq >>> 20) & 0xff;\n buf[offset++] = 0x80 | ((seq >>> 14) & 0x3f);\n buf[offset++] = (seq >>> 6) & 0xff;\n buf[offset++] = ((seq << 2) & 0xff) | (rnds[10] & 0x03);\n buf[offset++] = rnds[11];\n buf[offset++] = rnds[12];\n buf[offset++] = rnds[13];\n buf[offset++] = rnds[14];\n buf[offset++] = rnds[15];\n return buf;\n}\nexport default v7;\n", "import { InMemoryOps, Pagination } from '../query-plan'\nimport { doKeysMatch } from '../utils'\n\nexport function processRecords(value: unknown, ops: InMemoryOps): unknown {\n if (value == null) {\n return value\n }\n\n if (typeof value === 'string') {\n return processRecords(JSON.parse(value), ops)\n }\n\n if (Array.isArray(value)) {\n return processManyRecords(value as Record<string, unknown>[], ops)\n }\n\n return processOneRecord(value as Record<string, unknown>, ops)\n}\n\nfunction processOneRecord(record: Record<string, unknown>, ops: InMemoryOps): Record<string, unknown> | null {\n if (ops.pagination) {\n const { skip, take, cursor } = ops.pagination\n if (skip !== null && skip > 0) {\n return null\n }\n if (take === 0) {\n return null\n }\n if (cursor !== null && !doKeysMatch(record, cursor)) {\n return null\n }\n }\n return processNestedRecords(record, ops.nested)\n}\n\nfunction processNestedRecords(\n record: Record<string, unknown>,\n opsMap: Record<string, InMemoryOps>,\n): Record<string, unknown> {\n for (const [key, ops] of Object.entries(opsMap)) {\n record[key] = processRecords(record[key], ops)\n }\n return record\n}\n\nfunction processManyRecords(records: Record<string, unknown>[], ops: InMemoryOps): Record<string, unknown>[] {\n if (ops.distinct !== null) {\n const fields = ops.linkingFields !== null ? [...ops.distinct, ...ops.linkingFields] : ops.distinct\n records = distinctBy(records, fields)\n }\n\n if (ops.pagination) {\n records = paginate(records, ops.pagination, ops.linkingFields)\n }\n\n if (ops.reverse) {\n records.reverse()\n }\n\n if (Object.keys(ops.nested).length === 0) {\n return records\n }\n\n return records.map((record) => processNestedRecords(record, ops.nested))\n}\n\nfunction distinctBy(records: Record<string, unknown>[], fields: string[]): Record<string, unknown>[] {\n const seen = new Set()\n const result: Record<string, unknown>[] = []\n for (const record of records) {\n const key = getRecordKey(record, fields)\n if (!seen.has(key)) {\n seen.add(key)\n result.push(record)\n }\n }\n return result\n}\n\nfunction paginate(records: {}[], pagination: Pagination, linkingFields: string[] | null): {}[] {\n if (linkingFields === null) {\n return paginateSingleList(records, pagination)\n }\n\n const groupedByParent = new Map<string, {}[]>()\n for (const record of records) {\n const parentKey = getRecordKey(record, linkingFields)\n if (!groupedByParent.has(parentKey)) {\n groupedByParent.set(parentKey, [])\n }\n groupedByParent.get(parentKey)!.push(record)\n }\n\n const groupList = Array.from(groupedByParent.entries())\n groupList.sort(([aId], [bId]) => (aId < bId ? -1 : aId > bId ? 1 : 0))\n\n return groupList.flatMap(([, elems]) => paginateSingleList(elems, pagination))\n}\n\nfunction paginateSingleList(list: {}[], { cursor, skip, take }: Pagination): {}[] {\n const cursorIndex = cursor !== null ? list.findIndex((item) => doKeysMatch(item, cursor)) : 0\n if (cursorIndex === -1) {\n return []\n }\n const start = cursorIndex + (skip ?? 0)\n const end = take !== null ? start + take : list.length\n\n return list.slice(start, end)\n}\n\n/*\n * Generate a key string for a record based on the values of the specified fields.\n */\nexport function getRecordKey(record: {}, fields: string[]): string {\n return JSON.stringify(fields.map((field) => record[field]))\n}\n", "import { ArgType, Arity } from '@prisma/driver-adapter-utils'\n\nexport type PrismaValuePlaceholder = { prisma__type: 'param'; prisma__value: { name: string; type: string } }\n\nexport function isPrismaValuePlaceholder(value: unknown): value is PrismaValuePlaceholder {\n return typeof value === 'object' && value !== null && value['prisma__type'] === 'param'\n}\n\nexport type PrismaValueGenerator = {\n prisma__type: 'generatorCall'\n prisma__value: { name: string; args: PrismaValue[] }\n}\n\nexport function isPrismaValueGenerator(value: unknown): value is PrismaValueGenerator {\n return typeof value === 'object' && value !== null && value['prisma__type'] === 'generatorCall'\n}\n\nexport type PrismaValue =\n | string\n | boolean\n | number\n | PrismaValue[]\n | null\n | Record<string, unknown>\n | PrismaValuePlaceholder\n | PrismaValueGenerator\n\nexport type ResultNode =\n | {\n type: 'affectedRows'\n }\n | {\n type: 'object'\n fields: Record<string, ResultNode>\n serializedName: string | null\n skipNulls: boolean\n }\n | {\n type: 'field'\n dbName: string\n fieldType: FieldType\n }\n\nexport type QueryPlanBinding = {\n name: string\n expr: QueryPlanNode\n}\n\nexport type QueryPlanDbQuery =\n | {\n type: 'rawSql'\n sql: string\n args: PrismaValue[]\n argTypes: ArgType[]\n }\n | {\n type: 'templateSql'\n fragments: Fragment[]\n placeholderFormat: PlaceholderFormat\n args: PrismaValue[]\n argTypes: DynamicArgType[]\n chunkable: boolean\n }\n\nexport type DynamicArgType = ArgType | { arity: 'tuple'; elements: ArgType[] }\n\nexport type Fragment =\n | { type: 'stringChunk'; chunk: string }\n | { type: 'parameter' }\n | { type: 'parameterTuple' }\n | {\n type: 'parameterTupleList'\n itemPrefix: string\n itemSeparator: string\n itemSuffix: string\n groupSeparator: string\n }\n\nexport interface PlaceholderFormat {\n prefix: string\n hasNumbering: boolean\n}\n\nexport type JoinExpression = {\n child: QueryPlanNode\n on: [left: string, right: string][]\n parentField: string\n isRelationUnique: boolean\n}\n\nexport type QueryPlanNode =\n | {\n type: 'value'\n args: PrismaValue\n }\n | {\n type: 'seq'\n args: QueryPlanNode[]\n }\n | {\n type: 'get'\n args: {\n name: string\n }\n }\n | {\n type: 'let'\n args: {\n bindings: QueryPlanBinding[]\n expr: QueryPlanNode\n }\n }\n | {\n type: 'getFirstNonEmpty'\n args: {\n names: string[]\n }\n }\n | {\n type: 'query'\n args: QueryPlanDbQuery\n }\n | {\n type: 'execute'\n args: QueryPlanDbQuery\n }\n | {\n type: 'reverse'\n args: QueryPlanNode\n }\n | {\n type: 'sum'\n args: QueryPlanNode[]\n }\n | {\n type: 'concat'\n args: QueryPlanNode[]\n }\n | {\n type: 'unique'\n args: QueryPlanNode\n }\n | {\n type: 'required'\n args: QueryPlanNode\n }\n | {\n type: 'join'\n args: {\n parent: QueryPlanNode\n children: JoinExpression[]\n }\n }\n | {\n type: 'mapField'\n args: {\n field: string\n records: QueryPlanNode\n }\n }\n | {\n type: 'transaction'\n args: QueryPlanNode\n }\n | {\n type: 'dataMap'\n args: {\n expr: QueryPlanNode\n structure: ResultNode\n enums: Record<string, Record<string, string>>\n }\n }\n | {\n type: 'validate'\n args: {\n expr: QueryPlanNode\n rules: DataRule[]\n } & ValidationError\n }\n | {\n type: 'if'\n args: {\n value: QueryPlanNode\n rule: DataRule\n then: QueryPlanNode\n else: QueryPlanNode\n }\n }\n | {\n type: 'unit'\n }\n | {\n type: 'diff'\n args: {\n from: QueryPlanNode\n to: QueryPlanNode\n fields: string[]\n }\n }\n | {\n type: 'initializeRecord'\n args: {\n expr: QueryPlanNode\n fields: Record<string, FieldInitializer>\n }\n }\n | {\n type: 'mapRecord'\n args: {\n expr: QueryPlanNode\n fields: Record<string, FieldOperation>\n }\n }\n | {\n type: 'process'\n args: {\n expr: QueryPlanNode\n operations: InMemoryOps\n }\n }\n\nexport type FieldInitializer = { type: 'value'; value: PrismaValue } | { type: 'lastInsertId' }\n\nexport type FieldOperation =\n | { type: 'set'; value: PrismaValue }\n | { type: 'add'; value: PrismaValue }\n | { type: 'subtract'; value: PrismaValue }\n | { type: 'multiply'; value: PrismaValue }\n | { type: 'divide'; value: PrismaValue }\n\nexport type Pagination = {\n cursor: Record<string, PrismaValue> | null\n take: number | null\n skip: number | null\n}\n\nexport type InMemoryOps = {\n pagination: Pagination | null\n distinct: string[] | null\n reverse: boolean\n linkingFields: string[] | null\n nested: Record<string, InMemoryOps>\n}\n\nexport type DataRule =\n | {\n type: 'rowCountEq'\n args: number\n }\n | {\n type: 'rowCountNeq'\n args: number\n }\n | {\n type: 'affectedRowCountEq'\n args: number\n }\n | {\n type: 'never'\n }\n\nexport type ValidationError =\n | {\n error_identifier: 'RELATION_VIOLATION'\n context: {\n relation: string\n modelA: string\n modelB: string\n }\n }\n | {\n error_identifier: 'MISSING_RELATED_RECORD'\n context: {\n model: string\n relation: string\n relationType: string\n operation: string\n neededFor?: string\n }\n }\n | {\n error_identifier: 'MISSING_RECORD'\n context: {\n operation: string\n }\n }\n | {\n error_identifier: 'INCOMPLETE_CONNECT_INPUT'\n context: {\n expectedRows: number\n }\n }\n | {\n error_identifier: 'INCOMPLETE_CONNECT_OUTPUT'\n context: {\n expectedRows: number\n relation: string\n relationType: string\n }\n }\n | {\n error_identifier: 'RECORDS_NOT_CONNECTED'\n context: {\n relation: string\n parent: string\n child: string\n }\n }\n\nexport type FieldType = { arity: Arity } & FieldScalarType\n\nexport type FieldScalarType =\n | {\n type:\n | 'string'\n | 'int'\n | 'bigint'\n | 'float'\n | 'boolean'\n | 'json'\n | 'object'\n | 'datetime'\n | 'decimal'\n | 'unsupported'\n }\n | { type: 'enum'; name: string }\n | { type: 'bytes'; encoding: 'array' | 'base64' | 'hex' }\n", "import { ArgType, SqlQuery } from '@prisma/driver-adapter-utils'\n\nimport {\n DynamicArgType,\n type Fragment,\n isPrismaValueGenerator,\n isPrismaValuePlaceholder,\n type PlaceholderFormat,\n type PrismaValueGenerator,\n type PrismaValuePlaceholder,\n type QueryPlanDbQuery,\n} from '../query-plan'\nimport { UserFacingError } from '../user-facing-error'\nimport { assertNever } from '../utils'\nimport { GeneratorRegistrySnapshot } from './generators'\nimport { ScopeBindings } from './scope'\n\nexport function renderQuery(\n dbQuery: QueryPlanDbQuery,\n scope: ScopeBindings,\n generators: GeneratorRegistrySnapshot,\n maxChunkSize?: number,\n): SqlQuery[] {\n const args = dbQuery.args.map((arg) => evaluateArg(arg, scope, generators))\n\n switch (dbQuery.type) {\n case 'rawSql':\n return [renderRawSql(dbQuery.sql, args, dbQuery.argTypes)]\n case 'templateSql': {\n const chunks = dbQuery.chunkable ? chunkParams(dbQuery.fragments, args, maxChunkSize) : [args]\n return chunks.map((params) => {\n if (maxChunkSize !== undefined && params.length > maxChunkSize) {\n throw new UserFacingError('The query parameter limit supported by your database is exceeded.', 'P2029')\n }\n\n return renderTemplateSql(dbQuery.fragments, dbQuery.placeholderFormat, params, dbQuery.argTypes)\n })\n }\n default:\n assertNever(dbQuery['type'], `Invalid query type`)\n }\n}\n\nexport function evaluateArg(arg: unknown, scope: ScopeBindings, generators: GeneratorRegistrySnapshot): unknown {\n while (doesRequireEvaluation(arg)) {\n if (isPrismaValuePlaceholder(arg)) {\n const found = scope[arg.prisma__value.name]\n if (found === undefined) {\n throw new Error(`Missing value for query variable ${arg.prisma__value.name}`)\n }\n arg = found\n } else if (isPrismaValueGenerator(arg)) {\n const { name, args } = arg.prisma__value\n const generator = generators[name]\n if (!generator) {\n throw new Error(`Encountered an unknown generator '${name}'`)\n }\n arg = generator.generate(...args.map((arg) => evaluateArg(arg, scope, generators)))\n } else {\n assertNever(arg, `Unexpected unevaluated value type: ${arg}`)\n }\n }\n\n if (Array.isArray(arg)) {\n arg = arg.map((el) => evaluateArg(el, scope, generators))\n }\n\n return arg\n}\n\nfunction renderTemplateSql(\n fragments: Fragment[],\n placeholderFormat: PlaceholderFormat,\n params: unknown[],\n argTypes: DynamicArgType[],\n): SqlQuery {\n let sql = ''\n const ctx = { placeholderNumber: 1 }\n const flattenedParams: unknown[] = []\n const flattenedArgTypes: ArgType[] = []\n\n for (const fragment of pairFragmentsWithParams(fragments, params, argTypes)) {\n sql += renderFragment(fragment, placeholderFormat, ctx)\n if (fragment.type === 'stringChunk') {\n continue\n }\n const length = flattenedParams.length\n const added = flattenedParams.push(...flattenedFragmentParams(fragment)) - length\n\n if (fragment.argType.arity === 'tuple') {\n if (added % fragment.argType.elements.length !== 0) {\n throw new Error(\n `Malformed query template. Expected the number of parameters to match the tuple arity, but got ${added} parameters for a tuple of arity ${fragment.argType.elements.length}.`,\n )\n }\n // If we have a tuple, we just expand its elements repeatedly.\n for (let i = 0; i < added / fragment.argType.elements.length; i++) {\n flattenedArgTypes.push(...fragment.argType.elements)\n }\n } else {\n // If we have a non-tuple, we just expand the single type repeatedly.\n for (let i = 0; i < added; i++) {\n flattenedArgTypes.push(fragment.argType)\n }\n }\n }\n\n return {\n sql,\n args: flattenedParams,\n argTypes: flattenedArgTypes,\n }\n}\n\nfunction renderFragment<Type extends DynamicArgType | undefined>(\n fragment: FragmentWithParams<Type>,\n placeholderFormat: PlaceholderFormat,\n ctx: { placeholderNumber: number },\n): string {\n const fragmentType = fragment.type\n switch (fragmentType) {\n case 'parameter':\n return formatPlaceholder(placeholderFormat, ctx.placeholderNumber++)\n\n case 'stringChunk':\n return fragment.chunk\n\n case 'parameterTuple': {\n const placeholders =\n fragment.value.length == 0\n ? 'NULL'\n : fragment.value.map(() => formatPlaceholder(placeholderFormat, ctx.placeholderNumber++)).join(',')\n return `(${placeholders})`\n }\n\n case 'parameterTupleList': {\n return fragment.value\n .map((tuple) => {\n const elements = tuple\n .map(() => formatPlaceholder(placeholderFormat, ctx.placeholderNumber++))\n .join(fragment.itemSeparator)\n return `${fragment.itemPrefix}${elements}${fragment.itemSuffix}`\n })\n .join(fragment.groupSeparator)\n }\n\n default:\n assertNever(fragmentType, 'Invalid fragment type')\n }\n}\n\nfunction formatPlaceholder(placeholderFormat: PlaceholderFormat, placeholderNumber: number): string {\n return placeholderFormat.hasNumbering ? `${placeholderFormat.prefix}${placeholderNumber}` : placeholderFormat.prefix\n}\n\nfunction renderRawSql(sql: string, args: unknown[], argTypes: ArgType[]): SqlQuery {\n return {\n sql,\n args: args,\n argTypes,\n }\n}\n\nfunction doesRequireEvaluation(param: unknown): param is PrismaValuePlaceholder | PrismaValueGenerator {\n return isPrismaValuePlaceholder(param) || isPrismaValueGenerator(param)\n}\n\ntype FragmentWithParams<Type extends DynamicArgType | undefined = undefined> = Fragment &\n (\n | { type: 'stringChunk' }\n | { type: 'parameter'; value: unknown; argType: Type }\n | { type: 'parameterTuple'; value: unknown[]; argType: Type }\n | { type: 'parameterTupleList'; value: unknown[][]; argType: Type }\n )\n\nfunction* pairFragmentsWithParams<Types>(\n fragments: Fragment[],\n params: unknown[],\n argTypes: Types,\n): Generator<FragmentWithParams<Types extends DynamicArgType[] ? DynamicArgType : undefined>> {\n let index = 0\n\n for (const fragment of fragments) {\n switch (fragment.type) {\n case 'parameter': {\n if (index >= params.length) {\n throw new Error(`Malformed query template. Fragments attempt to read over ${params.length} parameters.`)\n }\n\n yield { ...fragment, value: params[index], argType: argTypes?.[index] }\n index++\n break\n }\n\n case 'stringChunk': {\n yield fragment\n break\n }\n\n case 'parameterTuple': {\n if (index >= params.length) {\n throw new Error(`Malformed query template. Fragments attempt to read over ${params.length} parameters.`)\n }\n\n const value = params[index]\n yield { ...fragment, value: Array.isArray(value) ? value : [value], argType: argTypes?.[index] }\n index++\n break\n }\n\n case 'parameterTupleList': {\n if (index >= params.length) {\n throw new Error(`Malformed query template. Fragments attempt to read over ${params.length} parameters.`)\n }\n\n const value = params[index]\n if (!Array.isArray(value)) {\n throw new Error(`Malformed query template. Tuple list expected.`)\n }\n if (value.length === 0) {\n throw new Error(`Malformed query template. Tuple list cannot be empty.`)\n }\n for (const tuple of value) {\n if (!Array.isArray(tuple)) {\n throw new Error(`Malformed query template. Tuple expected.`)\n }\n }\n\n yield { ...fragment, value, argType: argTypes?.[index] }\n index++\n break\n }\n }\n }\n}\n\nfunction* flattenedFragmentParams<Type extends DynamicArgType | undefined>(\n fragment: FragmentWithParams<Type>,\n): Generator<unknown, undefined, undefined> {\n switch (fragment.type) {\n case 'parameter':\n yield fragment.value\n break\n case 'stringChunk':\n break\n case 'parameterTuple':\n yield* fragment.value\n break\n case 'parameterTupleList':\n for (const tuple of fragment.value) {\n yield* tuple\n }\n break\n }\n}\n\nfunction chunkParams(fragments: Fragment[], params: unknown[], maxChunkSize?: number): unknown[][] {\n // Find out the total number of parameters once flattened and what the maximum number of\n // parameters in a single fragment is.\n let totalParamCount = 0\n let maxParamsPerFragment = 0\n for (const fragment of pairFragmentsWithParams(fragments, params, undefined)) {\n let paramSize = 0\n for (const _ of flattenedFragmentParams(fragment)) {\n void _\n paramSize++\n }\n maxParamsPerFragment = Math.max(maxParamsPerFragment, paramSize)\n totalParamCount += paramSize\n }\n\n let chunkedParams: unknown[][] = [[]]\n for (const fragment of pairFragmentsWithParams(fragments, params, undefined)) {\n switch (fragment.type) {\n case 'parameter': {\n for (const params of chunkedParams) {\n params.push(fragment.value)\n }\n break\n }\n\n case 'stringChunk': {\n break\n }\n\n case 'parameterTuple': {\n const thisParamCount = fragment.value.length\n let chunks: unknown[][] = []\n\n if (\n maxChunkSize &&\n // Have we split the parameters into chunks already?\n chunkedParams.length === 1 &&\n // Is this the fragment that has the most parameters?\n thisParamCount === maxParamsPerFragment &&\n // Do we need chunking to fit the parameters?\n totalParamCount > maxChunkSize &&\n // Would chunking enable us to fit the parameters?\n totalParamCount - thisParamCount < maxChunkSize\n ) {\n const availableSize = maxChunkSize - (totalParamCount - thisParamCount)\n chunks = chunkArray(fragment.value, availableSize)\n } else {\n chunks = [fragment.value]\n }\n\n chunkedParams = chunkedParams.flatMap((params) => chunks.map((chunk) => [...params, chunk]))\n break\n }\n\n case 'parameterTupleList': {\n const thisParamCount = fragment.value.reduce((acc, tuple) => acc + tuple.length, 0)\n\n const completeChunks: unknown[][][] = []\n let currentChunk: unknown[][] = []\n let currentChunkParamCount = 0\n\n for (const tuple of fragment.value) {\n if (\n maxChunkSize &&\n // Have we split the parameters into chunks already?\n chunkedParams.length === 1 &&\n // Is this the fragment that has the most parameters?\n thisParamCount === maxParamsPerFragment &&\n // Is there anything in the current chunk?\n currentChunk.length > 0 &&\n // Will adding this tuple exceed the max chunk size?\n totalParamCount - thisParamCount + currentChunkParamCount + tuple.length > maxChunkSize\n ) {\n completeChunks.push(currentChunk)\n currentChunk = []\n currentChunkParamCount = 0\n }\n currentChunk.push(tuple)\n currentChunkParamCount += tuple.length\n }\n\n if (currentChunk.length > 0) {\n completeChunks.push(currentChunk)\n }\n\n chunkedParams = chunkedParams.flatMap((params) => completeChunks.map((chunk) => [...params, chunk]))\n break\n }\n }\n }\n\n return chunkedParams\n}\n\nfunction chunkArray<T>(array: T[], chunkSize: number): T[][] {\n const result: T[][] = []\n for (let i = 0; i < array.length; i += chunkSize) {\n result.push(array.slice(i, i + chunkSize))\n }\n return result\n}\n", "import { type ColumnType, ColumnTypeEnum, type SqlResultSet } from '@prisma/driver-adapter-utils'\n\nimport { assertNever } from '../utils'\n\nexport function serializeSql(resultSet: SqlResultSet): Record<string, unknown>[] {\n return resultSet.rows.map((row) =>\n row.reduce<Record<string, unknown>>((acc, value, index) => {\n acc[resultSet.columnNames[index]] = value\n return acc\n }, {}),\n )\n}\n\nexport function serializeRawSql(resultSet: SqlResultSet): Record<string, unknown> {\n return {\n columns: resultSet.columnNames,\n types: resultSet.columnTypes.map((type) => serializeColumnType(type)),\n rows: resultSet.rows.map((row) =>\n row.map((value, index) => serializeRawValue(value, resultSet.columnTypes[index])),\n ),\n }\n}\n\nfunction serializeRawValue(value: unknown, type: ColumnType): unknown {\n if (value === null) {\n return null\n }\n\n switch (type) {\n case ColumnTypeEnum.Int32:\n switch (typeof value) {\n case 'number':\n return Math.trunc(value)\n case 'string':\n return Math.trunc(Number(value))\n default:\n throw new Error(`Cannot serialize value of type ${typeof value} as Int32`)\n }\n\n case ColumnTypeEnum.Int32Array:\n if (!Array.isArray(value)) {\n throw new Error(`Cannot serialize value of type ${typeof value} as Int32Array`)\n }\n return value.map((v) => serializeRawValue(v, ColumnTypeEnum.Int32))\n\n case ColumnTypeEnum.Int64:\n switch (typeof value) {\n case 'number':\n return BigInt(Math.trunc(value))\n case 'string':\n return value\n default:\n throw new Error(`Cannot serialize value of type ${typeof value} as Int64`)\n }\n\n case ColumnTypeEnum.Int64Array:\n if (!Array.isArray(value)) {\n throw new Error(`Cannot serialize value of type ${typeof value} as Int64Array`)\n }\n return value.map((v) => serializeRawValue(v, ColumnTypeEnum.Int64))\n\n case ColumnTypeEnum.Json:\n switch (typeof value) {\n case 'string':\n return JSON.parse(value)\n default:\n throw new Error(`Cannot serialize value of type ${typeof value} as Json`)\n }\n\n case ColumnTypeEnum.JsonArray:\n if (!Array.isArray(value)) {\n throw new Error(`Cannot serialize value of type ${typeof value} as JsonArray`)\n }\n return value.map((v) => serializeRawValue(v, ColumnTypeEnum.Json))\n\n case ColumnTypeEnum.Boolean:\n switch (typeof value) {\n case 'boolean':\n return value\n case 'string':\n return value === 'true' || value === '1'\n case 'number':\n return value === 1\n default:\n throw new Error(`Cannot serialize value of type ${typeof value} as Boolean`)\n }\n\n case ColumnTypeEnum.BooleanArray:\n if (!Array.isArray(value)) {\n throw new Error(`Cannot serialize value of type ${typeof value} as BooleanArray`)\n }\n return value.map((v) => serializeRawValue(v, ColumnTypeEnum.Boolean))\n\n default:\n return value // For all other types, return the value as is\n }\n}\n\n// maps JS column types to their Rust equivalents\nfunction serializeColumnType(columnType: ColumnType): string {\n switch (columnType) {\n case ColumnTypeEnum.Int32:\n return 'int'\n case ColumnTypeEnum.Int64:\n return 'bigint'\n case ColumnTypeEnum.Float:\n return 'float'\n case ColumnTypeEnum.Double:\n return 'double'\n case ColumnTypeEnum.Text:\n return 'string'\n case ColumnTypeEnum.Enum:\n return 'enum'\n case ColumnTypeEnum.Bytes:\n return 'bytes'\n case ColumnTypeEnum.Boolean:\n return 'bool'\n case ColumnTypeEnum.Character:\n return 'char'\n case ColumnTypeEnum.Numeric:\n return 'decimal'\n case ColumnTypeEnum.Json:\n return 'json'\n case ColumnTypeEnum.Uuid:\n return 'uuid'\n case ColumnTypeEnum.DateTime:\n return 'datetime'\n case ColumnTypeEnum.Date:\n return 'date'\n case ColumnTypeEnum.Time:\n return 'time'\n case ColumnTypeEnum.Int32Array:\n return 'int-array'\n case ColumnTypeEnum.Int64Array:\n return 'bigint-array'\n case ColumnTypeEnum.FloatArray:\n return 'float-array'\n case ColumnTypeEnum.DoubleArray:\n return 'double-array'\n case ColumnTypeEnum.TextArray:\n return 'string-array'\n case ColumnTypeEnum.EnumArray:\n return 'string-array'\n case ColumnTypeEnum.BytesArray:\n return 'bytes-array'\n case ColumnTypeEnum.BooleanArray:\n return 'bool-array'\n case ColumnTypeEnum.CharacterArray:\n return 'char-array'\n case ColumnTypeEnum.NumericArray:\n return 'decimal-array'\n case ColumnTypeEnum.JsonArray:\n return 'json-array'\n case ColumnTypeEnum.UuidArray:\n return 'uuid-array'\n case ColumnTypeEnum.DateTimeArray:\n return 'datetime-array'\n case ColumnTypeEnum.DateArray:\n return 'date-array'\n case ColumnTypeEnum.TimeArray:\n return 'time-array'\n case ColumnTypeEnum.UnknownNumber:\n return 'unknown'\n /// The following PlanetScale type IDs are mapped into Set:\n /// - SET (SET) -> e.g. `\"foo,bar\"` (String-encoded, comma-separated)\n case ColumnTypeEnum.Set:\n return 'string'\n default:\n assertNever(columnType, `Unexpected column type: ${columnType}`)\n }\n}\n", "import { DataRule, ValidationError } from '../query-plan'\nimport { UserFacingError } from '../user-facing-error'\nimport { assertNever } from '../utils'\n\nexport function performValidation(data: unknown, rules: DataRule[], error: ValidationError) {\n if (!rules.every((rule) => doesSatisfyRule(data, rule))) {\n const message = renderMessage(data, error)\n const code = getErrorCode(error)\n throw new UserFacingError(message, code, error.context)\n }\n}\n\nexport function doesSatisfyRule(data: unknown, rule: DataRule): boolean {\n switch (rule.type) {\n case 'rowCountEq':\n if (Array.isArray(data)) {\n return data.length === rule.args\n }\n if (data === null) {\n return rule.args === 0\n }\n return rule.args === 1\n\n case 'rowCountNeq':\n if (Array.isArray(data)) {\n return data.length !== rule.args\n }\n if (data === null) {\n return rule.args !== 0\n }\n return rule.args !== 1\n\n case 'affectedRowCountEq':\n return data === rule.args\n\n case 'never':\n return false\n\n default:\n assertNever(rule, `Unknown rule type: ${(rule as DataRule).type}`)\n }\n}\n\nfunction renderMessage(data: unknown, error: ValidationError): string {\n switch (error.error_identifier) {\n case 'RELATION_VIOLATION':\n return `The change you are trying to make would violate the required relation '${error.context.relation}' between the \\`${error.context.modelA}\\` and \\`${error.context.modelB}\\` models.`\n case 'MISSING_RECORD':\n return `An operation failed because it depends on one or more records that were required but not found. No record was found for ${error.context.operation}.`\n case 'MISSING_RELATED_RECORD': {\n const hint = error.context.neededFor ? ` (needed to ${error.context.neededFor})` : ''\n return `An operation failed because it depends on one or more records that were required but not found. No '${error.context.model}' record${hint} was found for ${error.context.operation} on ${error.context.relationType} relation '${error.context.relation}'.`\n }\n case 'INCOMPLETE_CONNECT_INPUT':\n return `An operation failed because it depends on one or more records that were required but not found. Expected ${\n error.context.expectedRows\n } records to be connected, found only ${Array.isArray(data) ? data.length : data}.`\n case 'INCOMPLETE_CONNECT_OUTPUT':\n return `The required connected records were not found. Expected ${\n error.context.expectedRows\n } records to be connected after connect operation on ${error.context.relationType} relation '${\n error.context.relation\n }', found ${Array.isArray(data) ? data.length : data}.`\n case 'RECORDS_NOT_CONNECTED':\n return `The records for relation \\`${error.context.relation}\\` between the \\`${error.context.parent}\\` and \\`${error.context.child}\\` models are not connected.`\n\n default:\n assertNever(error, `Unknown error identifier: ${error}`)\n }\n}\n\nfunction getErrorCode(error: ValidationError): string {\n switch (error.error_identifier) {\n case 'RELATION_VIOLATION':\n return 'P2014'\n case 'RECORDS_NOT_CONNECTED':\n return 'P2017'\n case 'INCOMPLETE_CONNECT_OUTPUT':\n return 'P2018'\n case 'MISSING_RECORD':\n case 'MISSING_RELATED_RECORD':\n case 'INCOMPLETE_CONNECT_INPUT':\n return 'P2025'\n\n default:\n assertNever(error, `Unknown error identifier: ${error}`)\n }\n}\n", "import { ConnectionInfo, SqlQuery, SqlQueryable, SqlResultSet } from '@prisma/driver-adapter-utils'\nimport type { SqlCommenterPlugin, SqlCommenterQueryInfo } from '@prisma/sqlcommenter'\n\nimport { QueryEvent } from '../events'\nimport { FieldInitializer, FieldOperation, JoinExpression, QueryPlanNode } from '../query-plan'\nimport { type SchemaProvider } from '../schema'\nimport { appendSqlComment, buildSqlComment } from '../sql-commenter'\nimport { type TracingHelper, withQuerySpanAndEvent } from '../tracing'\nimport { type TransactionManager } from '../transaction-manager/transaction-manager'\nimport { rethrowAsUserFacing, rethrowAsUserFacingRawError } from '../user-facing-error'\nimport { assertNever } from '../utils'\nimport { applyDataMap } from './data-mapper'\nimport { GeneratorRegistry, GeneratorRegistrySnapshot } from './generators'\nimport { getRecordKey, processRecords } from './in-memory-processing'\nimport { evaluateArg, renderQuery } from './render-query'\nimport { PrismaObject, ScopeBindings, Value } from './scope'\nimport { serializeRawSql, serializeSql } from './serialize-sql'\nimport { doesSatisfyRule, performValidation } from './validation'\n\nexport type QueryInterpreterTransactionManager = { enabled: true; manager: TransactionManager } | { enabled: false }\n\nexport type QueryInterpreterOptions = {\n onQuery?: (event: QueryEvent) => void\n tracingHelper: TracingHelper\n serializer: (results: SqlResultSet) => Value\n rawSerializer?: (results: SqlResultSet) => Value\n provider?: SchemaProvider\n connectionInfo?: ConnectionInfo\n}\n\nexport type QueryRuntimeOptions = {\n queryable: SqlQueryable\n transactionManager: QueryInterpreterTransactionManager\n scope: Record<string, unknown>\n sqlCommenter?: QueryInterpreterSqlCommenter\n}\n\ntype QueryRuntimeContext = {\n queryable: SqlQueryable\n transactionManager: QueryInterpreterTransactionManager\n scope: Record<string, unknown>\n generators: GeneratorRegistrySnapshot\n sqlCommenter?: QueryInterpreterSqlCommenter\n}\n\nexport type QueryInterpreterSqlCommenter = {\n plugins: SqlCommenterPlugin[]\n queryInfo: SqlCommenterQueryInfo\n}\n\nexport class QueryInterpreter {\n readonly #onQuery?: (event: QueryEvent) => void\n readonly #generators: GeneratorRegistry = new GeneratorRegistry()\n readonly #tracingHelper: TracingHelper\n readonly #serializer: (results: SqlResultSet) => Value\n readonly #rawSerializer: (results: SqlResultSet) => Value\n readonly #provider?: SchemaProvider\n readonly #connectionInfo?: ConnectionInfo\n\n constructor({\n onQuery,\n tracingHelper,\n serializer,\n rawSerializer,\n provider,\n connectionInfo,\n }: QueryInterpreterOptions) {\n this.#onQuery = onQuery\n this.#tracingHelper = tracingHelper\n this.#serializer = serializer\n this.#rawSerializer = rawSerializer ?? serializer\n this.#provider = provider\n this.#connectionInfo = connectionInfo\n }\n\n static forSql(options: {\n onQuery?: (event: QueryEvent) => void\n tracingHelper: TracingHelper\n provider?: SchemaProvider\n connectionInfo?: ConnectionInfo\n }): QueryInterpreter {\n return new QueryInterpreter({\n onQuery: options.onQuery,\n tracingHelper: options.tracingHelper,\n serializer: serializeSql,\n rawSerializer: serializeRawSql,\n provider: options.provider,\n connectionInfo: options.connectionInfo,\n })\n }\n\n async run(queryPlan: QueryPlanNode, options: QueryRuntimeOptions): Promise<unknown> {\n const { value } = await this.interpretNode(queryPlan, {\n ...options,\n generators: this.#generators.snapshot(),\n }).catch((e) => rethrowAsUserFacing(e))\n\n return value\n }\n\n private async interpretNode(node: QueryPlanNode, context: QueryRuntimeContext): Promise<IntermediateValue> {\n switch (node.type) {\n case 'value': {\n return {\n value: evaluateArg(node.args, context.scope, context.generators),\n }\n }\n\n case 'seq': {\n let result: IntermediateValue | undefined\n for (const arg of node.args) {\n result = await this.interpretNode(arg, context)\n }\n return result ?? { value: undefined }\n }\n\n case 'get': {\n return { value: context.scope[node.args.name] }\n }\n\n case 'let': {\n const nestedScope: ScopeBindings = Object.create(context.scope)\n for (const binding of node.args.bindings) {\n const { value } = await this.interpretNode(binding.expr, { ...context, scope: nestedScope })\n nestedScope[binding.name] = value\n }\n return this.interpretNode(node.args.expr, { ...context, scope: nestedScope })\n }\n\n case 'getFirstNonEmpty': {\n for (const name of node.args.names) {\n const value = context.scope[name]\n if (!isEmpty(value)) {\n return { value }\n }\n }\n return { value: [] }\n }\n\n case 'concat': {\n const parts = await Promise.all(\n node.args.map((arg) => this.interpretNode(arg, context).then((res) => res.value)),\n )\n return {\n value: parts.length > 0 ? parts.reduce<Value[]>((acc, part) => acc.concat(asList(part)), []) : [],\n }\n }\n\n case 'sum': {\n const parts = await Promise.all(\n node.args.map((arg) => this.interpretNode(arg, context).then((res) => res.value)),\n )\n return {\n value: parts.length > 0 ? parts.reduce((acc, part) => asNumber(acc) + asNumber(part)) : 0,\n }\n }\n\n case 'execute': {\n const queries = renderQuery(node.args, context.scope, context.generators, this.#maxChunkSize())\n\n let sum = 0\n for (const query of queries) {\n const commentedQuery = applyComments(query, context.sqlCommenter)\n sum += await this.#withQuerySpanAndEvent(commentedQuery, context.queryable, () =>\n context.queryable\n .executeRaw(commentedQuery)\n .catch((err) =>\n node.args.type === 'rawSql' ? rethrowAsUserFacingRawError(err) : rethrowAsUserFacing(err),\n ),\n )\n }\n\n return { value: sum }\n }\n\n case 'query': {\n const queries = renderQuery(node.args, context.scope, context.generators, this.#maxChunkSize())\n\n let results: SqlResultSet | undefined\n for (const query of queries) {\n const commentedQuery = applyComments(query, context.sqlCommenter)\n const result = await this.#withQuerySpanAndEvent(commentedQuery, context.queryable, () =>\n context.queryable\n .queryRaw(commentedQuery)\n .catch((err) =>\n node.args.type === 'rawSql' ? rethrowAsUserFacingRawError(err) : rethrowAsUserFacing(err),\n ),\n )\n if (results === undefined) {\n results = result\n } else {\n results.rows.push(...result.rows)\n results.lastInsertId = result.lastInsertId\n }\n }\n\n return {\n value: node.args.type === 'rawSql' ? this.#rawSerializer(results!) : this.#serializer(results!),\n lastInsertId: results?.lastInsertId,\n }\n }\n\n case 'reverse': {\n const { value, lastInsertId } = await this.interpretNode(node.args, context)\n return { value: Array.isArray(value) ? value.reverse() : value, lastInsertId }\n }\n\n case 'unique': {\n const { value, lastInsertId } = await this.interpretNode(node.args, context)\n if (!Array.isArray(value)) {\n return { value, lastInsertId }\n }\n if (value.length > 1) {\n throw new Error(`Expected zero or one element, got ${value.length}`)\n }\n return { value: value[0] ?? null, lastInsertId }\n }\n\n case 'required': {\n const { value, lastInsertId } = await this.interpretNode(node.args, context)\n if (isEmpty(value)) {\n throw new Error('Required value is empty')\n }\n return { value, lastInsertId }\n }\n\n case 'mapField': {\n const { value, lastInsertId } = await this.interpretNode(node.args.records, context)\n return { value: mapField(value, node.args.field), lastInsertId }\n }\n\n case 'join': {\n const { value: parent, lastInsertId } = await this.interpretNode(node.args.parent, context)\n\n if (parent === null) {\n return { value: null, lastInsertId }\n }\n\n const children = (await Promise.all(\n node.args.children.map(async (joinExpr) => ({\n joinExpr,\n childRecords: (await this.interpretNode(joinExpr.child, context)).value,\n })),\n )) satisfies JoinExpressionWithRecords[]\n\n return { value: attachChildrenToParents(parent, children), lastInsertId }\n }\n\n case 'transaction': {\n if (!context.transactionManager.enabled) {\n return this.interpretNode(node.args, context)\n }\n\n const transactionManager = context.transactionManager.manager\n const transactionInfo = await transactionManager.startInternalTransaction()\n const transaction = await transactionManager.getTransaction(transactionInfo, 'query')\n try {\n const value = await this.interpretNode(node.args, { ...context, queryable: transaction })\n await transactionManager.commitTransaction(transactionInfo.id)\n return value\n } catch (e) {\n await transactionManager.rollbackTransaction(transactionInfo.id)\n throw e\n }\n }\n\n case 'dataMap': {\n const { value, lastInsertId } = await this.interpretNode(node.args.expr, context)\n return { value: applyDataMap(value, node.args.structure, node.args.enums), lastInsertId }\n }\n\n case 'validate': {\n const { value, lastInsertId } = await this.interpretNode(node.args.expr, context)\n performValidation(value, node.args.rules, node.args)\n\n return { value, lastInsertId }\n }\n\n case 'if': {\n const { value } = await this.interpretNode(node.args.value, context)\n if (doesSatisfyRule(value, node.args.rule)) {\n return await this.interpretNode(node.args.then, context)\n } else {\n return await this.interpretNode(node.args.else, context)\n }\n }\n\n case 'unit': {\n return { value: undefined }\n }\n\n case 'diff': {\n const { value: from } = await this.interpretNode(node.args.from, context)\n const { value: to } = await this.interpretNode(node.args.to, context)\n\n const keyGetter = (item: Value) => (item !== null ? getRecordKey(asRecord(item), node.args.fields) : null)\n\n const toSet = new Set(asList(to).map(keyGetter))\n return { value: asList(from).filter((item) => !toSet.has(keyGetter(item))) }\n }\n\n case 'process': {\n const { value, lastInsertId } = await this.interpretNode(node.args.expr, context)\n return { value: processRecords(value, node.args.operations), lastInsertId }\n }\n\n case 'initializeRecord': {\n const { lastInsertId } = await this.interpretNode(node.args.expr, context)\n\n const record = {}\n for (const [key, initializer] of Object.entries(node.args.fields)) {\n record[key] = evalFieldInitializer(initializer, lastInsertId, context.scope, context.generators)\n }\n return { value: record, lastInsertId }\n }\n\n case 'mapRecord': {\n const { value, lastInsertId } = await this.interpretNode(node.args.expr, context)\n\n const record = value === null ? {} : asRecord(value)\n for (const [key, entry] of Object.entries(node.args.fields)) {\n record[key] = evalFieldOperation(entry, record[key], context.scope, context.generators)\n }\n return { value: record, lastInsertId }\n }\n\n default:\n assertNever(node, `Unexpected node type: ${(node as { type: unknown }).type}`)\n }\n }\n\n #maxChunkSize(): number | undefined {\n if (this.#connectionInfo?.maxBindValues !== undefined) {\n return this.#connectionInfo.maxBindValues\n }\n return this.#providerMaxChunkSize()\n }\n\n #providerMaxChunkSize(): number | undefined {\n if (this.#provider === undefined) {\n return undefined\n }\n switch (this.#provider) {\n case 'cockroachdb':\n case 'postgres':\n case 'postgresql':\n case 'prisma+postgres':\n return 32766\n case 'mysql':\n return 65535\n case 'sqlite':\n return 999\n case 'sqlserver':\n return 2098\n case 'mongodb':\n return undefined\n default:\n assertNever(this.#provider, `Unexpected provider: ${this.#provider}`)\n }\n }\n\n #withQuerySpanAndEvent<T>(query: SqlQuery, queryable: SqlQueryable, execute: () => Promise<T>): Promise<T> {\n return withQuerySpanAndEvent({\n query,\n execute,\n provider: this.#provider ?? queryable.provider,\n tracingHelper: this.#tracingHelper,\n onQuery: this.#onQuery,\n })\n }\n}\n\ntype IntermediateValue = { value: Value; lastInsertId?: string }\n\nfunction isEmpty(value: Value): boolean {\n if (Array.isArray(value)) {\n return value.length === 0\n }\n return value == null\n}\n\nfunction asList(value: Value): Value[] {\n return Array.isArray(value) ? value : [value]\n}\n\nfunction asNumber(value: Value): number {\n if (typeof value === 'number') {\n return value\n }\n\n if (typeof value === 'string') {\n return Number(value)\n }\n\n throw new Error(`Expected number, got ${typeof value}`)\n}\n\nfunction asRecord(value: Value): PrismaObject {\n if (typeof value === 'object' && value !== null) {\n return value as PrismaObject\n }\n throw new Error(`Expected object, got ${typeof value}`)\n}\n\nfunction mapField(value: Value, field: string): Value {\n if (Array.isArray(value)) {\n return value.map((element) => mapField(element, field))\n }\n\n if (typeof value === 'object' && value !== null) {\n return value[field] ?? null\n }\n\n return value\n}\n\ntype JoinExpressionWithRecords = {\n joinExpr: JoinExpression\n childRecords: Value\n}\n\nfunction attachChildrenToParents(parentRecords: unknown, children: JoinExpressionWithRecords[]) {\n for (const { joinExpr, childRecords } of children) {\n const parentKeys = joinExpr.on.map(([k]) => k)\n const childKeys = joinExpr.on.map(([, k]) => k)\n const parentMap = {}\n\n for (const parent of Array.isArray(parentRecords) ? parentRecords : [parentRecords]) {\n const parentRecord = asRecord(parent)\n const key = getRecordKey(parentRecord, parentKeys)\n if (!parentMap[key]) {\n parentMap[key] = []\n }\n parentMap[key].push(parentRecord)\n\n if (joinExpr.isRelationUnique) {\n parentRecord[joinExpr.parentField] = null\n } else {\n parentRecord[joinExpr.parentField] = []\n }\n }\n\n for (const childRecord of Array.isArray(childRecords) ? childRecords : [childRecords]) {\n if (childRecord === null) {\n continue\n }\n\n const key = getRecordKey(asRecord(childRecord), childKeys)\n for (const parentRecord of parentMap[key] ?? []) {\n if (joinExpr.isRelationUnique) {\n parentRecord[joinExpr.parentField] = childRecord\n } else {\n parentRecord[joinExpr.parentField].push(childRecord)\n }\n }\n }\n }\n\n return parentRecords\n}\n\nfunction evalFieldInitializer(\n initializer: FieldInitializer,\n lastInsertId: string | undefined,\n scope: ScopeBindings,\n generators: GeneratorRegistrySnapshot,\n): Value {\n switch (initializer.type) {\n case 'value':\n return evaluateArg(initializer.value, scope, generators)\n case 'lastInsertId':\n return lastInsertId\n default:\n assertNever(initializer, `Unexpected field initializer type: ${initializer['type']}`)\n }\n}\n\nfunction evalFieldOperation(\n op: FieldOperation,\n value: Value,\n scope: ScopeBindings,\n generators: GeneratorRegistrySnapshot,\n): Value {\n switch (op.type) {\n case 'set':\n return evaluateArg(op.value, scope, generators)\n case 'add':\n return asNumber(value) + asNumber(evaluateArg(op.value, scope, generators))\n case 'subtract':\n return asNumber(value) - asNumber(evaluateArg(op.value, scope, generators))\n case 'multiply':\n return asNumber(value) * asNumber(evaluateArg(op.value, scope, generators))\n case 'divide': {\n const lhs = asNumber(value)\n const rhs = asNumber(evaluateArg(op.value, scope, generators))\n // SQLite and older versions of MySQL return NULL for division by zero, so we emulate\n // that behavior here.\n // If the database does not permit division by zero, a database error should be raised,\n // preventing this case from being executed.\n if (rhs === 0) {\n return null\n }\n return lhs / rhs\n }\n default:\n assertNever(op, `Unexpected field operation type: ${op['type']}`)\n }\n}\n\nfunction applyComments(query: SqlQuery, sqlCommenter?: QueryInterpreterSqlCommenter): SqlQuery {\n if (!sqlCommenter || sqlCommenter.plugins.length === 0) {\n return query\n }\n\n const comment = buildSqlComment(sqlCommenter.plugins, {\n query: sqlCommenter.queryInfo,\n sql: query.sql,\n })\n\n if (!comment) {\n return query\n }\n\n return {\n ...query,\n sql: appendSqlComment(query.sql, comment),\n }\n}\n", "type Crypto = {\n randomUUID: () => string\n}\n\nasync function getCrypto(): Promise<Crypto> {\n // TODO: always use `globalThis.crypto` when we drop Node.js 18 support\n return globalThis.crypto ?? (await import('node:crypto'))\n}\n\nexport async function randomUUID(): Promise<string> {\n const crypto = await getCrypto()\n return crypto.randomUUID()\n}\n", "/**\n * Equivalent to `once` from `node:events` for DOM {@link EventTarget}.\n *\n * It is useful, e.g., to wait for an `abort` event on {@link AbortSignal}.\n * While in Node.js `AbortSignal` does implement `EventEmitter` interface\n * and is compatible with the `once` utility in `node:events`, it is not\n * necessarily the case in other JS runtimes.\n */\nexport async function once(target: EventTarget, event: string): Promise<Event> {\n return new Promise((resolve) => {\n target.addEventListener(event, resolve, { once: true })\n })\n}\n", "import { UserFacingError } from '../user-facing-error'\n\nexport class TransactionManagerError extends UserFacingError {\n name = 'TransactionManagerError'\n\n constructor(message: string, meta?: Record<string, unknown>) {\n super('Transaction API error: ' + message, 'P2028', meta)\n }\n}\n\nexport class TransactionNotFoundError extends TransactionManagerError {\n constructor() {\n super(\n \"Transaction not found. Transaction ID is invalid, refers to an old closed transaction Prisma doesn't have information about anymore, or was obtained before disconnecting.\",\n )\n }\n}\n\nexport class TransactionClosedError extends TransactionManagerError {\n constructor(operation: string) {\n super(`Transaction already closed: A ${operation} cannot be executed on a committed transaction.`)\n }\n}\n\nexport class TransactionRolledBackError extends TransactionManagerError {\n constructor(operation: string) {\n super(`Transaction already closed: A ${operation} cannot be executed on a transaction that was rolled back.`)\n }\n}\n\nexport class TransactionStartTimeoutError extends TransactionManagerError {\n constructor() {\n super('Unable to start a transaction in the given time.')\n }\n}\n\nexport class TransactionExecutionTimeoutError extends TransactionManagerError {\n constructor(operation: string, { timeout, timeTaken }: { timeout: number; timeTaken: number }) {\n super(\n `A ${operation} cannot be executed on an expired transaction. \\\nThe timeout for this transaction was ${timeout} ms, however ${timeTaken} ms passed since the start \\\nof the transaction. Consider increasing the interactive transaction timeout \\\nor doing less work in the transaction.`,\n { operation, timeout, timeTaken },\n )\n }\n}\n\nexport class TransactionInternalConsistencyError extends TransactionManagerError {\n constructor(message: string) {\n super(`Internal Consistency Error: ${message}`)\n }\n}\n\nexport class InvalidTransactionIsolationLevelError extends TransactionManagerError {\n constructor(isolationLevel: string) {\n super(`Invalid isolation level: ${isolationLevel}`, { isolationLevel })\n }\n}\n", "import { Debug } from '@prisma/debug'\nimport { SqlDriverAdapter, SqlQuery, SqlQueryable, Transaction } from '@prisma/driver-adapter-utils'\n\nimport { randomUUID } from '../crypto'\nimport { QueryEvent } from '../events'\nimport type { SchemaProvider } from '../schema'\nimport { TracingHelper, withQuerySpanAndEvent } from '../tracing'\nimport { rethrowAsUserFacing } from '../user-facing-error'\nimport { assertNever } from '../utils'\nimport { once } from '../web-platform'\nimport { Options, TransactionInfo } from './transaction'\nimport {\n InvalidTransactionIsolationLevelError,\n TransactionClosedError,\n TransactionExecutionTimeoutError,\n TransactionInternalConsistencyError,\n TransactionManagerError,\n TransactionNotFoundError,\n TransactionRolledBackError,\n TransactionStartTimeoutError,\n} from './transaction-manager-error'\n\nconst MAX_CLOSED_TRANSACTIONS = 100\n\ntype TransactionWrapper = {\n id: string\n timer?: NodeJS.Timeout\n timeout: number | undefined\n startedAt: number\n transaction?: Transaction\n} & TransactionState\n\ntype TransactionState =\n | { status: 'waiting' | 'running' | 'committed' | 'rolled_back' | 'timed_out' }\n | { status: 'closing'; closing: Promise<void>; reason: 'committed' | 'rolled_back' | 'timed_out' }\n\nconst debug = Debug('prisma:client:transactionManager')\n\nconst COMMIT_QUERY = (): SqlQuery => ({ sql: 'COMMIT', args: [], argTypes: [] })\nconst ROLLBACK_QUERY = (): SqlQuery => ({ sql: 'ROLLBACK', args: [], argTypes: [] })\n\nconst PHANTOM_COMMIT_QUERY = (): SqlQuery => ({\n sql: '-- Implicit \"COMMIT\" query via underlying driver',\n args: [],\n argTypes: [],\n})\nconst PHANTOM_ROLLBACK_QUERY = (): SqlQuery => ({\n sql: '-- Implicit \"ROLLBACK\" query via underlying driver',\n args: [],\n argTypes: [],\n})\n\nexport class TransactionManager {\n // The map of active transactions.\n private transactions: Map<string, TransactionWrapper> = new Map()\n // List of last closed transactions. Max MAX_CLOSED_TRANSACTIONS entries.\n // Used to provide better error messages than a generic \"transaction not found\".\n private closedTransactions: TransactionWrapper[] = []\n private readonly driverAdapter: SqlDriverAdapter\n private readonly transactionOptions: Options\n private readonly tracingHelper: TracingHelper\n readonly #onQuery?: (event: QueryEvent) => void\n readonly #provider?: SchemaProvider\n\n constructor({\n driverAdapter,\n transactionOptions,\n tracingHelper,\n onQuery,\n provider,\n }: {\n driverAdapter: SqlDriverAdapter\n transactionOptions: Options\n tracingHelper: TracingHelper\n onQuery?: (event: QueryEvent) => void\n provider?: SchemaProvider\n }) {\n this.driverAdapter = driverAdapter\n this.transactionOptions = transactionOptions\n this.tracingHelper = tracingHelper\n this.#onQuery = onQuery\n this.#provider = provider\n }\n\n /**\n * Starts an internal transaction. The difference to `startTransaction` is that it does not\n * use the default transaction options from the `TransactionManager`, which in practice means\n * that it does not apply the default timeouts.\n */\n async startInternalTransaction(options?: Options): Promise<TransactionInfo> {\n const validatedOptions = options !== undefined ? this.#validateOptions(options) : {}\n return await this.tracingHelper.runInChildSpan('start_transaction', () =>\n this.#startTransactionImpl(validatedOptions),\n )\n }\n\n async startTransaction(options?: Options): Promise<TransactionInfo> {\n const validatedOptions = options !== undefined ? this.#validateOptions(options) : this.transactionOptions\n return await this.tracingHelper.runInChildSpan('start_transaction', () =>\n this.#startTransactionImpl(validatedOptions),\n )\n }\n\n async #startTransactionImpl(options: Options): Promise<TransactionInfo> {\n const transaction: TransactionWrapper = {\n id: await randomUUID(),\n status: 'waiting',\n timer: undefined,\n timeout: options.timeout,\n startedAt: Date.now(),\n transaction: undefined,\n }\n\n // Start timeout to wait for transaction to be started.\n const abortController = new AbortController()\n const startTimer = createTimeoutIfDefined(() => abortController.abort(), options.maxWait)\n startTimer?.unref?.()\n\n // Keep a reference to the startTransaction promise so we can clean up\n // if the timeout fires before it completes.\n const startTransactionPromise = this.driverAdapter\n .startTransaction(options.isolationLevel)\n .catch(rethrowAsUserFacing)\n\n transaction.transaction = await Promise.race([\n startTransactionPromise.finally(() => clearTimeout(startTimer)),\n once(abortController.signal, 'abort').then(() => undefined),\n ])\n\n this.transactions.set(transaction.id, transaction)\n\n // Transaction status might have timed out while waiting for transaction to start. => Check for it!\n switch (transaction.status) {\n case 'waiting':\n if (abortController.signal.aborted) {\n // The startTransaction promise may still be running in the background.\n // If it eventually succeeds, we need to release the connection to avoid\n // leaking it and exhausting the connection pool. We ignore any errors\n // that happen during startup or rollback here because we will have\n // already returned our own `TransactionStartTimeoutError` error to the user.\n void startTransactionPromise\n .then((tx) => tx.rollback())\n .catch((e) => debug('error in discarded transaction:', e))\n\n // Call `#closeTransaction` to update internal state. It won't actually attempt\n // to rollback the tx itself because `transaction.transaction` is undefined.\n await this.#closeTransaction(transaction, 'timed_out')\n\n throw new TransactionStartTimeoutError()\n }\n\n transaction.status = 'running'\n // Start timeout to wait for transaction to be finished.\n transaction.timer = this.#startTransactionTimeout(transaction.id, options.timeout)\n return { id: transaction.id }\n case 'timed_out':\n case 'running':\n case 'committed':\n case 'rolled_back':\n throw new TransactionInternalConsistencyError(\n `Transaction in invalid state ${transaction.status} although it just finished startup.`,\n )\n default:\n assertNever(transaction['status'], 'Unknown transaction status.')\n }\n }\n\n async commitTransaction(transactionId: string): Promise<void> {\n return await this.tracingHelper.runInChildSpan('commit_transaction', async () => {\n const txw = this.#getActiveOrClosingTransaction(transactionId, 'commit')\n await this.#closeTransaction(txw, 'committed')\n })\n }\n\n async rollbackTransaction(transactionId: string): Promise<void> {\n return await this.tracingHelper.runInChildSpan('rollback_transaction', async () => {\n const txw = this.#getActiveOrClosingTransaction(transactionId, 'rollback')\n await this.#closeTransaction(txw, 'rolled_back')\n })\n }\n\n async getTransaction(txInfo: TransactionInfo, operation: string): Promise<Transaction> {\n let tx = this.#getActiveOrClosingTransaction(txInfo.id, operation)\n if (tx.status === 'closing') {\n await tx.closing\n // Fetch again to ensure proper error propagation after it's been closed.\n tx = this.#getActiveOrClosingTransaction(txInfo.id, operation)\n }\n if (!tx.transaction) throw new TransactionNotFoundError()\n return tx.transaction\n }\n\n #getActiveOrClosingTransaction(transactionId: string, operation: string): TransactionWrapper {\n const transaction = this.transactions.get(transactionId)\n\n if (!transaction) {\n const closedTransaction = this.closedTransactions.find((tx) => tx.id === transactionId)\n if (closedTransaction) {\n debug('Transaction already closed.', { transactionId, status: closedTransaction.status })\n switch (closedTransaction.status) {\n case 'closing':\n case 'waiting':\n case 'running':\n throw new TransactionInternalConsistencyError('Active transaction found in closed transactions list.')\n case 'committed':\n throw new TransactionClosedError(operation)\n case 'rolled_back':\n throw new TransactionRolledBackError(operation)\n case 'timed_out':\n throw new TransactionExecutionTimeoutError(operation, {\n timeout: closedTransaction.timeout!,\n timeTaken: Date.now() - closedTransaction.startedAt,\n })\n }\n } else {\n debug(`Transaction not found.`, transactionId)\n throw new TransactionNotFoundError()\n }\n }\n\n if (['committed', 'rolled_back', 'timed_out'].includes(transaction.status)) {\n throw new TransactionInternalConsistencyError('Closed transaction found in active transactions map.')\n }\n\n return transaction\n }\n\n async cancelAllTransactions(): Promise<void> {\n // TODO: call `map` on the iterator directly without collecting it into an array first\n // once we drop support for Node.js 18 and 20.\n await Promise.allSettled([...this.transactions.values()].map((tx) => this.#closeTransaction(tx, 'rolled_back')))\n }\n\n #startTransactionTimeout(transactionId: string, timeout: number | undefined): NodeJS.Timeout | undefined {\n const timeoutStartedAt = Date.now()\n const timer = createTimeoutIfDefined(async () => {\n debug('Transaction timed out.', { transactionId, timeoutStartedAt, timeout })\n\n const tx = this.transactions.get(transactionId)\n if (tx && ['running', 'waiting'].includes(tx.status)) {\n await this.#closeTransaction(tx, 'timed_out')\n } else {\n // Transaction was already committed or rolled back when timeout happened.\n // Should normally not happen as timeout is cancelled when transaction is committed or rolled back.\n // No further action needed though.\n debug('Transaction already committed or rolled back when timeout happened.', transactionId)\n }\n }, timeout)\n\n timer?.unref?.()\n return timer\n }\n\n async #closeTransaction(tx: TransactionWrapper, status: 'committed' | 'rolled_back' | 'timed_out'): Promise<void> {\n const createClosingPromise = async () => {\n debug('Closing transaction.', { transactionId: tx.id, status })\n try {\n if (tx.transaction && status === 'committed') {\n if (tx.transaction.options.usePhantomQuery) {\n await this.#withQuerySpanAndEvent(PHANTOM_COMMIT_QUERY(), tx.transaction, () => tx.transaction!.commit())\n } else {\n const query = COMMIT_QUERY()\n await this.#withQuerySpanAndEvent(query, tx.transaction, () => tx.transaction!.executeRaw(query)).then(\n () => tx.transaction!.commit(),\n (err) => {\n const fail = () => Promise.reject(err)\n return tx.transaction!.rollback().then(fail, fail)\n },\n )\n }\n } else if (tx.transaction) {\n if (tx.transaction.options.usePhantomQuery) {\n await this.#withQuerySpanAndEvent(PHANTOM_ROLLBACK_QUERY(), tx.transaction, () =>\n tx.transaction!.rollback(),\n )\n } else {\n const query = ROLLBACK_QUERY()\n try {\n await this.#withQuerySpanAndEvent(query, tx.transaction, () => tx.transaction!.executeRaw(query))\n } finally {\n await tx.transaction.rollback()\n }\n }\n }\n } finally {\n tx.status = status\n clearTimeout(tx.timer)\n tx.timer = undefined\n\n this.transactions.delete(tx.id)\n\n this.closedTransactions.push(tx)\n if (this.closedTransactions.length > MAX_CLOSED_TRANSACTIONS) {\n this.closedTransactions.shift()\n }\n }\n }\n\n if (tx.status === 'closing') {\n await tx.closing\n // Fetch again to ensure proper error propagation after it's been closed.\n this.#getActiveOrClosingTransaction(tx.id, status === 'committed' ? 'commit' : 'rollback')\n } else {\n await Object.assign(tx, {\n status: 'closing',\n reason: status,\n closing: createClosingPromise(),\n }).closing\n }\n }\n\n #validateOptions(options: Options) {\n // Supplying timeout default values is cared for upstream already.\n if (!options.timeout) throw new TransactionManagerError('timeout is required')\n if (!options.maxWait) throw new TransactionManagerError('maxWait is required')\n\n // Snapshot level only supported for MS SQL Server, which is not supported via driver adapters so far.\n if (options.isolationLevel === 'SNAPSHOT') throw new InvalidTransactionIsolationLevelError(options.isolationLevel)\n\n return {\n ...options,\n timeout: options.timeout,\n maxWait: options.maxWait,\n }\n }\n\n #withQuerySpanAndEvent<T>(query: SqlQuery, queryable: SqlQueryable, execute: () => Promise<T>): Promise<T> {\n return withQuerySpanAndEvent({\n query,\n execute,\n provider: this.#provider ?? queryable.provider,\n tracingHelper: this.tracingHelper,\n onQuery: this.#onQuery,\n })\n }\n}\n\nfunction createTimeoutIfDefined(cb: () => void, ms: number | undefined): NodeJS.Timeout | undefined {\n return ms !== undefined ? setTimeout(cb, ms) : undefined\n}\n", "import { QueryCompiler, QueryCompilerConstructor, QueryEngineLogLevel } from '@prisma/client-common'\nimport {\n BatchResponse,\n convertCompactedRows,\n QueryEvent,\n QueryPlanNode,\n safeJsonStringify,\n TransactionInfo,\n UserFacingError,\n} from '@prisma/client-engine-runtime'\nimport {\n PrismaClientInitializationError,\n PrismaClientKnownRequestError,\n PrismaClientRustPanicError,\n PrismaClientUnknownRequestError,\n} from '@prisma/client-runtime-utils'\nimport { Debug } from '@prisma/debug'\nimport type { IsolationLevel as SqlIsolationLevel, SqlDriverAdapterFactory } from '@prisma/driver-adapter-utils'\nimport type { ActiveConnectorType } from '@prisma/generator'\nimport type { TracingHelper } from '@prisma/instrumentation-contract'\nimport { assertNever } from '@prisma/internals'\nimport type { JsonBatchQuery, JsonQuery, RawJsonQuery } from '@prisma/json-protocol'\nimport { ParamGraph } from '@prisma/param-graph'\n\nimport { version as clientVersion } from '../../../../../package.json'\nimport { deserializeRawParameters } from '../../../utils/deserializeRawParameters'\nimport type { BatchQueryEngineResult, EngineConfig, RequestBatchOptions, RequestOptions } from '../common/Engine'\nimport { Engine } from '../common/Engine'\nimport { LogEmitter, QueryEvent as ClientQueryEvent } from '../common/types/Events'\nimport { RustRequestError, SyncRustError } from '../common/types/QueryEngine'\nimport type * as Tx from '../common/types/Transaction'\nimport { InteractiveTransactionInfo } from '../common/types/Transaction'\nimport { getBatchRequestPayload } from '../common/utils/getBatchRequestPayload'\nimport { getErrorMessageWithLink as genericGetErrorMessageWithLink } from '../common/utils/getErrorMessageWithLink'\nimport type { Executor } from './Executor'\nimport { LocalExecutor } from './LocalExecutor'\nimport { parameterizeBatch, parameterizeQuery } from './parameterization/parameterize'\nimport { QueryPlanCache } from './QueryPlanCache'\nimport { RemoteExecutor } from './RemoteExecutor'\nimport { QueryCompilerLoader } from './types/QueryCompiler'\nimport { wasmQueryCompilerLoader } from './WasmQueryCompilerLoader'\n\nconst CLIENT_ENGINE_ERROR = 'P2038'\n\nconst debug = Debug('prisma:client:clientEngine')\n\ntype GlobalWithPanicHandler = typeof globalThis & {\n PRISMA_WASM_PANIC_REGISTRY: {\n set_message?: (message: string) => void\n }\n}\n\nconst globalWithPanicHandler = globalThis as GlobalWithPanicHandler\n\n// The fallback panic handler shared across all instances. This ensures that any\n// panic is caught and handled, but each instance should prefer temporarily\n// setting its own local panic handler for the duration of a synchronous WASM\n// function call for better error messages.\nglobalWithPanicHandler.PRISMA_WASM_PANIC_REGISTRY = {\n set_message(message: string) {\n throw new PrismaClientRustPanicError(message, clientVersion)\n },\n}\n\ninterface ConnectedEngine {\n executor: Executor\n queryCompiler: QueryCompiler\n}\n\ntype EngineState =\n | {\n type: 'disconnected'\n }\n | {\n type: 'connecting'\n promise: Promise<ConnectedEngine>\n }\n | {\n type: 'connected'\n engine: ConnectedEngine\n }\n | {\n type: 'disconnecting'\n promise: Promise<void>\n }\n\ntype ExecutorKind =\n | {\n remote: false\n driverAdapterFactory: SqlDriverAdapterFactory\n }\n | {\n remote: true\n accelerateUrl: string\n }\n\nexport class ClientEngine implements Engine {\n name = 'ClientEngine' as const\n\n #QueryCompilerConstructor?: QueryCompilerConstructor\n #state: EngineState = { type: 'disconnected' }\n #queryCompilerLoader: QueryCompilerLoader\n #executorKind: ExecutorKind\n #queryPlanCache: QueryPlanCache\n // todo: remove this\n #queryPlanCacheEnabled: boolean\n #paramGraph: ParamGraph\n\n config: EngineConfig\n datamodel: string\n\n logEmitter: LogEmitter\n logQueries: boolean\n logLevel: QueryEngineLogLevel\n tracingHelper: TracingHelper\n\n #emitQueryEvent?: (event: QueryEvent) => void\n\n constructor(config: EngineConfig, queryCompilerLoader?: QueryCompilerLoader) {\n if (config.accelerateUrl !== undefined) {\n this.#executorKind = { remote: true, accelerateUrl: config.accelerateUrl }\n } else if (config.adapter) {\n this.#executorKind = { remote: false, driverAdapterFactory: config.adapter }\n debug('Using driver adapter: %O', config.adapter)\n } else {\n throw new PrismaClientInitializationError(\n 'Missing configured driver adapter. Engine type `client` requires an active driver adapter. Please check your PrismaClient initialization code.',\n config.clientVersion,\n CLIENT_ENGINE_ERROR,\n )\n }\n\n if (TARGET_BUILD_TYPE === 'client' || TARGET_BUILD_TYPE === 'wasm-compiler-edge') {\n this.#queryCompilerLoader = queryCompilerLoader ?? wasmQueryCompilerLoader\n } else {\n throw new Error(`Invalid TARGET_BUILD_TYPE: ${TARGET_BUILD_TYPE}`)\n }\n\n this.config = config\n this.logQueries = config.logQueries ?? false\n this.logLevel = config.logLevel ?? 'error'\n this.logEmitter = config.logEmitter\n this.datamodel = config.inlineSchema\n this.tracingHelper = config.tracingHelper\n this.#queryPlanCache = new QueryPlanCache()\n this.#queryPlanCacheEnabled = true\n this.#paramGraph = ParamGraph.deserialize(config.parameterizationSchema, (enumName) => {\n if (!Object.hasOwn(config.runtimeDataModel.enums, enumName)) {\n return undefined\n }\n return config.runtimeDataModel.enums[enumName].values.map((v) => v.name)\n })\n\n if (config.enableDebugLogs) {\n this.logLevel = 'debug'\n }\n\n if (this.logQueries) {\n this.#emitQueryEvent = (event: QueryEvent) => {\n this.logEmitter.emit('query', {\n ...event,\n // TODO: we should probably change the interface to contain a proper array in the next major version.\n params: safeJsonStringify(event.params),\n // TODO: this field only exists for historical reasons as we grandfathered it from the time\n // when we emitted `tracing` events to stdout in the engine unchanged, and then described\n // them in the public API as TS types. Thus this field used to contain the name of the Rust\n // module in which an event originated. When using library engine, which uses a different\n // mechanism with a JavaScript callback for logs, it's normally just an empty string instead.\n // This field is definitely not useful and should be removed from the public types (but it's\n // technically a breaking change, even if a tiny and inconsequential one).\n target: 'ClientEngine',\n } satisfies ClientQueryEvent)\n }\n }\n }\n\n async #ensureStarted(): Promise<ConnectedEngine> {\n switch (this.#state.type) {\n case 'disconnected': {\n const connecting = this.tracingHelper.runInChildSpan('connect', async () => {\n let executor: Executor | undefined = undefined\n let queryCompiler: QueryCompiler | undefined = undefined\n\n try {\n executor = await this.#connectExecutor()\n queryCompiler = await this.#instantiateQueryCompiler(executor)\n } catch (error) {\n this.#state = { type: 'disconnected' }\n queryCompiler?.free()\n await executor?.disconnect()\n throw error\n }\n\n const engine: ConnectedEngine = {\n executor,\n queryCompiler,\n }\n\n this.#state = { type: 'connected', engine }\n\n return engine\n })\n\n this.#state = {\n type: 'connecting',\n promise: connecting,\n }\n\n return await connecting\n }\n\n case 'connecting':\n return await this.#state.promise\n\n case 'connected':\n return this.#state.engine\n\n case 'disconnecting':\n await this.#state.promise\n return await this.#ensureStarted()\n }\n }\n\n async #connectExecutor(): Promise<Executor> {\n if (this.#executorKind.remote) {\n return new RemoteExecutor({\n clientVersion: this.config.clientVersion,\n accelerateUrl: this.#executorKind.accelerateUrl,\n logEmitter: this.logEmitter,\n logLevel: this.logLevel,\n logQueries: this.logQueries,\n tracingHelper: this.tracingHelper,\n sqlCommenters: this.config.sqlCommenters,\n })\n } else {\n return await LocalExecutor.connect({\n driverAdapterFactory: this.#executorKind.driverAdapterFactory,\n tracingHelper: this.tracingHelper,\n transactionOptions: {\n ...this.config.transactionOptions,\n isolationLevel: this.#convertIsolationLevel(this.config.transactionOptions.isolationLevel),\n },\n onQuery: this.#emitQueryEvent,\n provider: this.config.activeProvider as ActiveConnectorType | undefined,\n sqlCommenters: this.config.sqlCommenters,\n })\n }\n }\n\n async #instantiateQueryCompiler(executor: Executor): Promise<QueryCompiler> {\n // We reuse the `QueryCompilerConstructor` from the same `WebAssembly.Instance` between\n // reconnects as long as there are no panics. This avoids the overhead of loading and\n // JIT compiling the WebAssembly module after every reconnect. If it panics, we discard\n // it and load a new one from scratch if the client reconnects again.\n let QueryCompilerConstructor = this.#QueryCompilerConstructor\n\n if (QueryCompilerConstructor === undefined) {\n QueryCompilerConstructor = await this.#queryCompilerLoader.loadQueryCompiler(this.config)\n this.#QueryCompilerConstructor = QueryCompilerConstructor\n }\n\n const { provider, connectionInfo } = await executor.getConnectionInfo()\n\n try {\n return this.#withLocalPanicHandler(\n () =>\n new QueryCompilerConstructor({\n datamodel: this.datamodel,\n provider,\n connectionInfo,\n }),\n undefined,\n false,\n )\n } catch (e) {\n throw this.#transformInitError(e)\n }\n }\n\n #transformInitError(err: Error): Error {\n if (err instanceof PrismaClientRustPanicError) {\n return err\n }\n try {\n const error: SyncRustError = JSON.parse(err.message)\n return new PrismaClientInitializationError(error.message, this.config.clientVersion, error.error_code)\n } catch (e) {\n return err\n }\n }\n\n #transformRequestError(err: any, query?: string): Error {\n if (err instanceof PrismaClientInitializationError) return err\n\n if (err.code === 'GenericFailure' && err.message?.startsWith('PANIC:'))\n return new PrismaClientRustPanicError(\n getErrorMessageWithLink(this, err.message, query),\n this.config.clientVersion,\n )\n\n if (err instanceof UserFacingError) {\n return new PrismaClientKnownRequestError(err.message, {\n code: err.code,\n meta: err.meta,\n clientVersion: this.config.clientVersion,\n })\n }\n\n try {\n const error: RustRequestError = JSON.parse(err as string)\n return new PrismaClientUnknownRequestError(`${error.message}\\n${error.backtrace}`, {\n clientVersion: this.config.clientVersion,\n })\n } catch (e) {\n return err\n }\n }\n\n #transformCompileError(error: any): any {\n if (error instanceof PrismaClientRustPanicError) {\n return error\n }\n\n if (typeof error['message'] === 'string' && typeof error['code'] === 'string') {\n return new PrismaClientKnownRequestError(error['message'], {\n code: error['code'],\n meta: error.meta,\n clientVersion: this.config.clientVersion,\n })\n } else if (typeof error['message'] === 'string') {\n return new PrismaClientUnknownRequestError(error['message'], { clientVersion: this.config.clientVersion })\n } else {\n return error\n }\n }\n\n #withLocalPanicHandler<T>(fn: () => T, query?: string, disconnectOnPanic = true): T {\n const previousHandler = globalWithPanicHandler.PRISMA_WASM_PANIC_REGISTRY.set_message\n let panic: string | undefined = undefined\n\n global.PRISMA_WASM_PANIC_REGISTRY.set_message = (message: string) => {\n panic = message\n }\n\n try {\n return fn()\n } finally {\n global.PRISMA_WASM_PANIC_REGISTRY.set_message = previousHandler\n\n if (panic) {\n // Discard the current `WebAssembly.Instance` to avoid memory leaks:\n // WebAssembly doesn't unwind the stack or call destructors on panic.\n this.#QueryCompilerConstructor = undefined\n // Disconnect and drop the compiler, unless this panic happened during\n // initialization. In that case, we let `#ensureStarted` deal with it\n // and change the state to `disconnected` by itself.\n if (disconnectOnPanic) {\n void this.stop().catch((err) => debug('failed to disconnect:', err))\n }\n // eslint-disable-next-line no-unsafe-finally\n throw new PrismaClientRustPanicError(getErrorMessageWithLink(this, panic, query), this.config.clientVersion)\n }\n }\n }\n\n onBeforeExit() {\n throw new Error(\n '\"beforeExit\" hook is not applicable to the client engine, it is only relevant and implemented for the binary engine. Please add your event listener to the `process` object directly instead.',\n )\n }\n\n async start(): Promise<void> {\n await this.#ensureStarted()\n }\n\n async stop(): Promise<void> {\n switch (this.#state.type) {\n case 'disconnected':\n return\n\n case 'connecting':\n await this.#state.promise\n return await this.stop()\n\n case 'connected': {\n const engine = this.#state.engine\n\n const disconnecting = this.tracingHelper.runInChildSpan('disconnect', async () => {\n try {\n await engine.executor.disconnect()\n engine.queryCompiler.free()\n } finally {\n this.#state = { type: 'disconnected' }\n }\n })\n\n this.#state = {\n type: 'disconnecting',\n promise: disconnecting,\n }\n\n return await disconnecting\n }\n\n case 'disconnecting':\n return await this.#state.promise\n }\n }\n\n version(): string {\n return 'unknown'\n }\n\n async transaction(\n action: 'start',\n headers: Tx.TransactionHeaders,\n options: Tx.Options,\n ): Promise<Tx.InteractiveTransactionInfo>\n async transaction(\n action: 'commit',\n headers: Tx.TransactionHeaders,\n info: Tx.InteractiveTransactionInfo,\n ): Promise<undefined>\n async transaction(\n action: 'rollback',\n headers: Tx.TransactionHeaders,\n info: Tx.InteractiveTransactionInfo,\n ): Promise<undefined>\n async transaction(\n action: 'start' | 'commit' | 'rollback',\n _headers: Tx.TransactionHeaders,\n arg?: any,\n ): Promise<Tx.InteractiveTransactionInfo | undefined> {\n let result: TransactionInfo | undefined\n\n const { executor } = await this.#ensureStarted()\n\n try {\n if (action === 'start') {\n const options: Tx.Options = arg\n result = await executor.startTransaction({\n ...options,\n isolationLevel: this.#convertIsolationLevel(options.isolationLevel),\n })\n } else if (action === 'commit') {\n const txInfo: Tx.InteractiveTransactionInfo<undefined> = arg\n await executor.commitTransaction(txInfo)\n } else if (action === 'rollback') {\n const txInfo: Tx.InteractiveTransactionInfo<undefined> = arg\n await executor.rollbackTransaction(txInfo)\n } else {\n assertNever(action, 'Invalid transaction action.')\n }\n } catch (error) {\n throw this.#transformRequestError(error)\n }\n\n return result ? { id: result.id, payload: undefined } : undefined\n }\n\n async request<T>(\n query: JsonQuery,\n { interactiveTransaction, customDataProxyFetch }: RequestOptions<unknown>,\n ): Promise<{ data: T }> {\n debug(`sending request`)\n\n const { executor, queryCompiler } = await this.#ensureStarted().catch((err) => {\n throw this.#transformRequestError(err, JSON.stringify(query))\n })\n\n let plan: QueryPlanNode\n let placeholderValues: Record<string, unknown> = {}\n\n if (isRawQuery(query)) {\n plan = compileRawQuery(query)\n } else if (this.#queryPlanCacheEnabled) {\n const { parameterizedQuery, placeholderValues: extractedValues } = parameterizeQuery(query, this.#paramGraph)\n const cacheKey = JSON.stringify(parameterizedQuery)\n placeholderValues = extractedValues\n\n const cached = this.#queryPlanCache.getSingle(cacheKey)\n if (cached) {\n debug('query plan cache hit')\n plan = cached\n } else {\n debug('query plan cache miss')\n plan = this.#compileQuery(parameterizedQuery, cacheKey, queryCompiler)\n this.#queryPlanCache.setSingle(cacheKey, plan)\n }\n } else {\n plan = this.#compileQuery(query, JSON.stringify(query), queryCompiler)\n }\n\n try {\n debug(`query plan created`, plan)\n\n const result = await executor.execute({\n plan,\n model: query.modelName,\n operation: query.action,\n placeholderValues,\n transaction: interactiveTransaction,\n batchIndex: undefined,\n customFetch: customDataProxyFetch?.(globalThis.fetch),\n queryInfo: {\n type: 'single',\n modelName: query.modelName,\n action: query.action,\n query: query.query,\n },\n })\n\n debug(`query plan executed`)\n\n return { data: { [query.action]: result } as T }\n } catch (e: any) {\n throw this.#transformRequestError(e, JSON.stringify(query))\n }\n }\n\n async requestBatch<T>(\n queries: JsonQuery[],\n { transaction, customDataProxyFetch }: RequestBatchOptions<unknown>,\n ): Promise<BatchQueryEngineResult<T>[]> {\n if (queries.length === 0) {\n return []\n }\n\n const firstAction = queries[0].action\n const firstModelName = queries[0].modelName\n\n const batchPayload = getBatchRequestPayload(queries, transaction)\n const request = JSON.stringify(batchPayload)\n\n const { executor, queryCompiler } = await this.#ensureStarted().catch((err) => {\n throw this.#transformRequestError(err, request)\n })\n\n const hasRawQueries = firstModelName === undefined\n let batchResponse: BatchResponse\n let placeholderValues: Record<string, unknown> = {}\n\n if (this.#queryPlanCacheEnabled && !hasRawQueries) {\n const { parameterizedBatch, placeholderValues: extractedValues } = parameterizeBatch(\n batchPayload as JsonBatchQuery,\n this.#paramGraph,\n )\n const cacheKeyStr = JSON.stringify(parameterizedBatch)\n placeholderValues = extractedValues\n\n const cached = this.#queryPlanCache.getBatch(cacheKeyStr)\n if (cached) {\n debug('batch query plan cache hit')\n batchResponse = cached\n } else {\n debug('batch query plan cache miss')\n try {\n batchResponse = this.#compileBatch(parameterizedBatch.batch, cacheKeyStr, queryCompiler)\n this.#queryPlanCache.setBatch(cacheKeyStr, batchResponse)\n } catch (error) {\n throw this.#transformCompileError(error)\n }\n }\n } else {\n batchResponse = this.#compileBatch(queries, request, queryCompiler)\n }\n\n try {\n let txInfo: InteractiveTransactionInfo | undefined\n if (transaction?.kind === 'itx') {\n // If we are already in an interactive transaction we do not nest transactions\n txInfo = transaction.options\n }\n\n switch (batchResponse.type) {\n case 'multi': {\n if (transaction?.kind !== 'itx') {\n const txOptions = transaction?.options.isolationLevel\n ? { ...this.config.transactionOptions, isolationLevel: transaction.options.isolationLevel }\n : this.config.transactionOptions\n txInfo = await this.transaction('start', {}, txOptions)\n }\n\n const results: BatchQueryEngineResult<unknown>[] = []\n let rollback = false\n for (const [batchIndex, plan] of batchResponse.plans.entries()) {\n try {\n const rows = await executor.execute({\n plan: plan as QueryPlanNode,\n placeholderValues,\n model: queries[batchIndex].modelName,\n operation: queries[batchIndex].action,\n batchIndex,\n transaction: txInfo,\n customFetch: customDataProxyFetch?.(globalThis.fetch) as typeof globalThis.fetch | undefined,\n queryInfo: {\n type: 'single',\n ...queries[batchIndex],\n },\n })\n results.push({ data: { [queries[batchIndex].action]: rows } })\n } catch (err) {\n results.push(err as Error)\n rollback = true\n break\n }\n }\n\n if (txInfo !== undefined && transaction?.kind !== 'itx') {\n if (rollback) {\n await this.transaction('rollback', {}, txInfo)\n } else {\n await this.transaction('commit', {}, txInfo)\n }\n }\n return results as BatchQueryEngineResult<T>[]\n }\n case 'compacted': {\n if (!queries.every((q) => q.action === firstAction && q.modelName === firstModelName)) {\n const actions = queries.map((q) => q.action).join(', ')\n const modelNames = queries.map((q) => q.modelName).join(', ')\n throw new Error(\n `Internal error: All queries in a compacted batch must have the same action and model name, but received actions: [${actions}] and model names: [${modelNames}]. ` +\n 'This indicates a bug in the client. Please report this issue to the Prisma team with your query details.',\n )\n }\n\n if (firstModelName === undefined) {\n throw new Error(\n 'Internal error: A compacted batch cannot contain raw queries. ' +\n 'This indicates a bug in the client. Please report this issue to the Prisma team with your query details.',\n )\n }\n\n const rows = await executor.execute({\n plan: batchResponse.plan as QueryPlanNode,\n placeholderValues,\n model: firstModelName,\n operation: firstAction,\n batchIndex: undefined,\n transaction: txInfo,\n customFetch: customDataProxyFetch?.(globalThis.fetch) as typeof globalThis.fetch | undefined,\n queryInfo: {\n type: 'compacted',\n action: firstAction,\n modelName: firstModelName,\n queries,\n },\n })\n\n const results = convertCompactedRows(rows as {}[], batchResponse, placeholderValues)\n return results.map((result) => ({ data: { [firstAction]: result } }) as BatchQueryEngineResult<T>)\n }\n }\n } catch (e: any) {\n throw this.#transformRequestError(e, request)\n }\n }\n\n /**\n * Used by `@prisma/extension-accelerate`\n */\n async apiKey(): Promise<string | null> {\n const { executor } = await this.#ensureStarted()\n return executor.apiKey()\n }\n\n #compileQuery(query: JsonQuery, request: string, compiler: QueryCompiler): QueryPlanNode {\n try {\n return this.#withLocalPanicHandler(() =>\n this.#withCompileSpan({\n queries: [query],\n execute: () => compiler.compile(request) as QueryPlanNode,\n }),\n )\n } catch (error) {\n throw this.#transformCompileError(error)\n }\n }\n\n #compileBatch(queries: JsonQuery[], request: string, compiler: QueryCompiler): BatchResponse {\n if (queries.every(isRawQuery)) {\n return {\n type: 'multi',\n plans: queries.map((q) => compileRawQuery(q)),\n }\n }\n\n try {\n return this.#withLocalPanicHandler(() =>\n this.#withCompileSpan({\n queries,\n execute: () => compiler.compileBatch(request),\n }),\n )\n } catch (err) {\n throw this.#transformCompileError(err)\n }\n }\n\n #convertIsolationLevel(clientIsolationLevel: Tx.IsolationLevel | undefined): SqlIsolationLevel | undefined {\n switch (clientIsolationLevel) {\n case undefined:\n return undefined\n case 'ReadUncommitted':\n return 'READ UNCOMMITTED'\n case 'ReadCommitted':\n return 'READ COMMITTED'\n case 'RepeatableRead':\n return 'REPEATABLE READ'\n case 'Serializable':\n return 'SERIALIZABLE'\n case 'Snapshot':\n return 'SNAPSHOT'\n default:\n throw new PrismaClientKnownRequestError(\n `Inconsistent column data: Conversion failed: Invalid isolation level \\`${\n clientIsolationLevel satisfies never\n }\\``,\n {\n code: 'P2023',\n clientVersion: this.config.clientVersion,\n meta: {\n providedIsolationLevel: clientIsolationLevel,\n },\n },\n )\n }\n }\n\n #withCompileSpan<T>({ queries, execute }: { queries: JsonQuery[]; execute: () => T }): T {\n return this.tracingHelper.runInChildSpan(\n {\n name: 'compile',\n attributes: {\n models: queries.map((q) => q.modelName).filter((m) => m !== undefined),\n actions: queries.map((q) => q.action),\n },\n },\n execute,\n )\n }\n}\n\nfunction getErrorMessageWithLink(engine: ClientEngine, title: string, query?: string) {\n return genericGetErrorMessageWithLink({\n binaryTarget: undefined,\n title,\n version: engine.config.clientVersion,\n engineVersion: 'unknown', // WASM engines do not export their version info\n database: engine.config.activeProvider as any,\n query,\n })\n}\n\nfunction isRawQuery(query: JsonQuery): query is RawJsonQuery {\n return query.action === 'queryRaw' || query.action === 'executeRaw'\n}\n\nfunction compileRawQuery(query: RawJsonQuery): QueryPlanNode {\n const sql = query.query.arguments.query\n const { args, argTypes } = deserializeRawParameters(query.query.arguments.parameters)\n return {\n type: query.action === 'queryRaw' ? 'query' : 'execute',\n args: { type: 'rawSql', sql, args, argTypes },\n }\n}\n", "/**\n * Binary serialization for ParamGraph.\n *\n * This module handles compact binary encoding/decoding of the param graph structure.\n * The format uses a hybrid approach: JSON string array for field names + binary blob\n * for structural data (nodes, edges, roots).\n *\n * ## Serialized Representation\n *\n * ```\n * SerializedParamGraph {\n * strings: string[] // String table (field names, enum names, root keys)\n * graph: string // Base64url-encoded binary blob\n * }\n * ```\n *\n * ## Why Hybrid?\n *\n * - **Strings stay as JSON**: V8's JSON.parse is highly optimized for string arrays\n * - **Structure goes binary**: Indices, flags, masks benefit from compact encoding\n * - **Best of both**: Fast parsing + compact size where it matters\n *\n * ## Variable-Length Encoding\n *\n * All integer values (except fixed-size fields like `scalarMask` and `flags`) use\n * unsigned LEB128 (Little Endian Base 128) variable-length encoding:\n *\n * - Values 0-127: 1 byte\n * - Values 128-16383: 2 bytes\n * - Values 16384-2097151: 3 bytes\n * - And so on...\n *\n * Optional values use value+1 encoding: 0 means \"none/undefined\", N+1 means actual value N.\n *\n * ## Binary Blob Layout\n *\n * ```\n * \u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n * \u2502 HEADER \u2502\n * \u251C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\n * \u2502 inputNodeCount: varuint \u2502\n * \u2502 outputNodeCount: varuint \u2502\n * \u2502 rootCount: varuint \u2502\n * \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n *\n * \u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n * \u2502 INPUT NODES (repeated inputNodeCount times) \u2502\n * \u251C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\n * \u2502 edgeCount: varuint \u2502\n * \u2502 edges[] \u2502\n * \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n *\n * \u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n * \u2502 INPUT EDGE \u2502\n * \u251C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\n * \u2502 fieldIndex: varuint \u2502\n * \u2502 scalarMask: u16 \u2502\n * \u2502 childNodeId: varuint (0=none, N+1=actual) \u2502\n * \u2502 enumNameIndex: varuint (0=none, N+1=actual) \u2502\n * \u2502 flags: u8 \u2502\n * \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n *\n * \u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n * \u2502 OUTPUT NODES (repeated outputNodeCount times) \u2502\n * \u251C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\n * \u2502 edgeCount: varuint \u2502\n * \u2502 edges[] \u2502\n * \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n *\n * \u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n * \u2502 OUTPUT EDGE \u2502\n * \u251C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\n * \u2502 fieldIndex: varuint \u2502\n * \u2502 argsNodeId: varuint (0=none, N+1=actual) \u2502\n * \u2502 outputNodeId: varuint (0=none, N+1=actual) \u2502\n * \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n *\n * \u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n * \u2502 ROOTS (repeated rootCount times) \u2502\n * \u251C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\n * \u2502 keyIndex: varuint \u2502\n * \u2502 argsNodeId: varuint (0=none, N+1=actual) \u2502\n * \u2502 outputNodeId: varuint (0=none, N+1=actual) \u2502\n * \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n * ```\n *\n * ## Embedding in Generated Client\n *\n * ```js\n * config.parameterizationSchema = {\n * strings: JSON.parse('[\"where\",\"id\",\"email\",...]'),\n * graph: \"base64url_encoded_binary_blob...\"\n * }\n * ```\n */\n\nimport type {\n InputEdgeData,\n InputNodeData,\n OutputEdgeData,\n OutputNodeData,\n ParamGraphData,\n RootEntryData,\n} from './types'\n\n/**\n * Serialized format stored in the generated client.\n */\nexport interface SerializedParamGraph {\n /** String table (field names, enum names, root keys) */\n strings: string[]\n /** Base64url-encoded binary blob for structural data */\n graph: string\n}\n\n/**\n * Serializes a ParamGraphData to the compact binary format.\n */\nexport function serializeParamGraph(data: ParamGraphData): SerializedParamGraph {\n return new Serializer(data).serialize()\n}\n\n/**\n * Deserializes a binary-encoded ParamGraph.\n */\nexport function deserializeParamGraph(serialized: SerializedParamGraph): ParamGraphData {\n return new Deserializer(serialized).deserialize()\n}\n\nfunction encodeBase64url(bytes: Uint8Array): string {\n return Buffer.from(bytes.buffer, bytes.byteOffset, bytes.byteLength).toString('base64url')\n}\n\nfunction decodeBase64url(str: string): Uint8Array {\n return Buffer.from(str, 'base64url')\n}\n\n/**\n * Calculates the number of bytes needed to encode a value as an unsigned LEB128 varint.\n */\nfunction varuintSize(value: number): number {\n let size = 1\n while (value >= 0x80) {\n size++\n value >>>= 7\n }\n return size\n}\n\nclass Serializer {\n #data: ParamGraphData\n #buffer: ArrayBuffer\n #view: DataView\n #offset: number = 0\n #rootKeys: string[]\n\n constructor(data: ParamGraphData) {\n this.#data = data\n this.#rootKeys = Object.keys(data.roots)\n\n const size = this.#calculateBufferSize()\n this.#buffer = new ArrayBuffer(size)\n this.#view = new DataView(this.#buffer)\n }\n\n serialize(): SerializedParamGraph {\n this.#writeHeader()\n this.#writeInputNodes()\n this.#writeOutputNodes()\n this.#writeRoots()\n\n return {\n strings: this.#data.strings,\n graph: encodeBase64url(new Uint8Array(this.#buffer, 0, this.#offset)),\n }\n }\n\n #writeVaruint(value: number): void {\n while (value >= 0x80) {\n this.#view.setUint8(this.#offset++, (value & 0x7f) | 0x80)\n value >>>= 7\n }\n this.#view.setUint8(this.#offset++, value)\n }\n\n #writeOptionalVaruint(value: number | undefined): void {\n this.#writeVaruint(value === undefined ? 0 : value + 1)\n }\n\n #writeByte(value: number): void {\n this.#view.setUint8(this.#offset, value)\n this.#offset += 1\n }\n\n #writeU16(value: number): void {\n this.#view.setUint16(this.#offset, value, true)\n this.#offset += 2\n }\n\n #calculateBufferSize(): number {\n let size = 0\n\n // Header: 3 varints\n size += varuintSize(this.#data.inputNodes.length)\n size += varuintSize(this.#data.outputNodes.length)\n size += varuintSize(this.#rootKeys.length)\n\n for (const node of this.#data.inputNodes) {\n const fieldIndices = Object.keys(node.edges).map(Number)\n size += varuintSize(fieldIndices.length)\n\n for (const fieldIndex of fieldIndices) {\n const edge = node.edges[fieldIndex]\n size += varuintSize(fieldIndex)\n size += 2 // scalarMask: u16\n size += varuintSize(edge.childNodeId === undefined ? 0 : edge.childNodeId + 1)\n size += varuintSize(edge.enumNameIndex === undefined ? 0 : edge.enumNameIndex + 1)\n size += 1 // flags: u8\n }\n }\n\n for (const node of this.#data.outputNodes) {\n const fieldIndices = Object.keys(node.edges).map(Number)\n size += varuintSize(fieldIndices.length)\n\n for (const fieldIndex of fieldIndices) {\n const edge = node.edges[fieldIndex]\n size += varuintSize(fieldIndex)\n size += varuintSize(edge.argsNodeId === undefined ? 0 : edge.argsNodeId + 1)\n size += varuintSize(edge.outputNodeId === undefined ? 0 : edge.outputNodeId + 1)\n }\n }\n\n for (const key of this.#rootKeys) {\n const root = this.#data.roots[key]\n const keyIndex = this.#data.strings.indexOf(key)\n size += varuintSize(keyIndex)\n size += varuintSize(root.argsNodeId === undefined ? 0 : root.argsNodeId + 1)\n size += varuintSize(root.outputNodeId === undefined ? 0 : root.outputNodeId + 1)\n }\n\n return size\n }\n\n #writeHeader(): void {\n this.#writeVaruint(this.#data.inputNodes.length)\n this.#writeVaruint(this.#data.outputNodes.length)\n this.#writeVaruint(this.#rootKeys.length)\n }\n\n #writeInputNodes(): void {\n for (const node of this.#data.inputNodes) {\n const fieldIndices = Object.keys(node.edges).map(Number)\n this.#writeVaruint(fieldIndices.length)\n\n for (const fieldIndex of fieldIndices) {\n const edge = node.edges[fieldIndex]\n\n this.#writeVaruint(fieldIndex)\n this.#writeU16(edge.scalarMask ?? 0)\n this.#writeOptionalVaruint(edge.childNodeId)\n this.#writeOptionalVaruint(edge.enumNameIndex)\n this.#writeByte(edge.flags)\n }\n }\n }\n\n #writeOutputNodes(): void {\n for (const node of this.#data.outputNodes) {\n const fieldIndices = Object.keys(node.edges).map(Number)\n this.#writeVaruint(fieldIndices.length)\n\n for (const fieldIndex of fieldIndices) {\n const edge = node.edges[fieldIndex]\n\n this.#writeVaruint(fieldIndex)\n this.#writeOptionalVaruint(edge.argsNodeId)\n this.#writeOptionalVaruint(edge.outputNodeId)\n }\n }\n }\n\n #writeRoots(): void {\n for (const key of this.#rootKeys) {\n const root = this.#data.roots[key]\n const keyIndex = this.#data.strings.indexOf(key)\n if (keyIndex === -1) {\n throw new Error(`Root key \"${key}\" not found in strings table`)\n }\n\n this.#writeVaruint(keyIndex)\n this.#writeOptionalVaruint(root.argsNodeId)\n this.#writeOptionalVaruint(root.outputNodeId)\n }\n }\n}\n\nclass Deserializer {\n #serialized: SerializedParamGraph\n #view: DataView\n #offset: number = 0\n\n constructor(serialized: SerializedParamGraph) {\n this.#serialized = serialized\n const bytes = decodeBase64url(serialized.graph)\n this.#view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength)\n }\n\n deserialize(): ParamGraphData {\n const { inputNodeCount, outputNodeCount, rootCount } = this.#readHeader()\n const inputNodes = this.#readInputNodes(inputNodeCount)\n const outputNodes = this.#readOutputNodes(outputNodeCount)\n const roots = this.#readRoots(rootCount)\n\n return {\n strings: this.#serialized.strings,\n inputNodes,\n outputNodes,\n roots,\n }\n }\n\n #readVaruint(): number {\n let value = 0\n let shift = 0\n let byte: number\n do {\n byte = this.#view.getUint8(this.#offset++)\n value |= (byte & 0x7f) << shift\n shift += 7\n } while (byte >= 0x80)\n return value\n }\n\n #readOptionalVaruint(): number | undefined {\n const value = this.#readVaruint()\n return value === 0 ? undefined : value - 1\n }\n\n #readByte(): number {\n const value = this.#view.getUint8(this.#offset)\n this.#offset += 1\n return value\n }\n\n #readU16(): number {\n const value = this.#view.getUint16(this.#offset, true)\n this.#offset += 2\n return value\n }\n\n #readHeader(): { inputNodeCount: number; outputNodeCount: number; rootCount: number } {\n const inputNodeCount = this.#readVaruint()\n const outputNodeCount = this.#readVaruint()\n const rootCount = this.#readVaruint()\n\n return { inputNodeCount, outputNodeCount, rootCount }\n }\n\n #readInputNodes(count: number): InputNodeData[] {\n const inputNodes: InputNodeData[] = []\n\n for (let i = 0; i < count; i++) {\n const edgeCount = this.#readVaruint()\n const edges: Record<number, InputEdgeData> = {}\n\n for (let j = 0; j < edgeCount; j++) {\n const fieldIndex = this.#readVaruint()\n const scalarMask = this.#readU16()\n const childNodeId = this.#readOptionalVaruint()\n const enumNameIndex = this.#readOptionalVaruint()\n const flags = this.#readByte()\n\n const edge: InputEdgeData = { flags }\n if (scalarMask !== 0) edge.scalarMask = scalarMask\n if (childNodeId !== undefined) edge.childNodeId = childNodeId\n if (enumNameIndex !== undefined) edge.enumNameIndex = enumNameIndex\n\n edges[fieldIndex] = edge\n }\n\n inputNodes.push({ edges })\n }\n\n return inputNodes\n }\n\n #readOutputNodes(count: number): OutputNodeData[] {\n const outputNodes: OutputNodeData[] = []\n\n for (let i = 0; i < count; i++) {\n const edgeCount = this.#readVaruint()\n const edges: Record<number, OutputEdgeData> = {}\n\n for (let j = 0; j < edgeCount; j++) {\n const fieldIndex = this.#readVaruint()\n const argsNodeId = this.#readOptionalVaruint()\n const outputNodeId = this.#readOptionalVaruint()\n\n const edge: OutputEdgeData = {}\n if (argsNodeId !== undefined) edge.argsNodeId = argsNodeId\n if (outputNodeId !== undefined) edge.outputNodeId = outputNodeId\n\n edges[fieldIndex] = edge\n }\n\n outputNodes.push({ edges })\n }\n\n return outputNodes\n }\n\n #readRoots(count: number): Record<string, RootEntryData> {\n const roots: Record<string, RootEntryData> = {}\n\n for (let i = 0; i < count; i++) {\n const keyIndex = this.#readVaruint()\n const argsNodeId = this.#readOptionalVaruint()\n const outputNodeId = this.#readOptionalVaruint()\n\n const key = this.#serialized.strings[keyIndex]\n const root: RootEntryData = {}\n if (argsNodeId !== undefined) root.argsNodeId = argsNodeId\n if (outputNodeId !== undefined) root.outputNodeId = outputNodeId\n\n roots[key] = root\n }\n\n return roots\n }\n}\n", "/**\n * ParamGraph: Runtime class for schema-aware parameterization.\n *\n * This class provides a readable API for navigating the param graph structure\n * at runtime. It's created once per PrismaClient instance from the serialized\n * format embedded in the generated client.\n */\n\nimport type { SerializedParamGraph } from './serialization'\nimport { deserializeParamGraph } from './serialization'\nimport type {\n InputEdgeData,\n InputNodeData,\n OutputEdgeData,\n OutputNodeData,\n ParamGraphData,\n RootEntryData,\n} from './types'\n\n/**\n * Function type for looking up enum values by name.\n * This allows ParamGraph to remain decoupled from RuntimeDataModel.\n */\nexport type EnumLookup = (enumName: string) => readonly string[] | undefined\n\n/**\n * Readable view of root entry.\n */\nexport interface RootEntry {\n readonly argsNodeId: number | undefined\n readonly outputNodeId: number | undefined\n}\n\n/**\n * Readable view of input node.\n */\nexport interface InputNode {\n readonly id: number\n}\n\n/**\n * Readable view of output node.\n */\nexport interface OutputNode {\n readonly id: number\n}\n\n/**\n * Readable view of input edge.\n */\nexport interface InputEdge {\n readonly flags: number\n readonly childNodeId: number | undefined\n readonly scalarMask: number\n readonly enumNameIndex: number | undefined\n}\n\n/**\n * Readable view of output edge.\n */\nexport interface OutputEdge {\n readonly argsNodeId: number | undefined\n readonly outputNodeId: number | undefined\n}\n\n/**\n * ParamGraph provides runtime access to the schema information\n * needed for parameterization decisions.\n */\nexport class ParamGraph {\n readonly #data: ParamGraphData\n readonly #stringIndex: Map<string, number>\n readonly #enumLookup: EnumLookup\n\n private constructor(data: ParamGraphData, enumLookup: EnumLookup) {\n this.#data = data\n this.#enumLookup = enumLookup\n\n // Build string-to-index map for O(1) lookups\n this.#stringIndex = new Map<string, number>()\n for (let i = 0; i < data.strings.length; i++) {\n this.#stringIndex.set(data.strings[i], i)\n }\n }\n\n /**\n * Creates a ParamGraph from serialized format.\n * This is the primary factory method for runtime use.\n */\n static deserialize(serialized: SerializedParamGraph, enumLookup: EnumLookup): ParamGraph {\n const data = deserializeParamGraph(serialized)\n return new ParamGraph(data, enumLookup)\n }\n\n /**\n * Creates a ParamGraph from builder data.\n * Used by the builder for testing and direct construction.\n */\n static fromData(data: ParamGraphData, enumLookup: EnumLookup): ParamGraph {\n return new ParamGraph(data, enumLookup)\n }\n\n /**\n * Look up a root entry by \"Model.action\" or \"action\".\n */\n root(key: string): RootEntry | undefined {\n const entry = this.#data.roots[key]\n if (!entry) {\n return undefined\n }\n return {\n argsNodeId: entry.argsNodeId,\n outputNodeId: entry.outputNodeId,\n }\n }\n\n /**\n * Get an input node by ID.\n */\n inputNode(id: number | undefined): InputNode | undefined {\n if (id === undefined || id < 0 || id >= this.#data.inputNodes.length) {\n return undefined\n }\n return { id }\n }\n\n /**\n * Get an output node by ID.\n */\n outputNode(id: number | undefined): OutputNode | undefined {\n if (id === undefined || id < 0 || id >= this.#data.outputNodes.length) {\n return undefined\n }\n return { id }\n }\n\n /**\n * Get an input edge for a field name within a node.\n */\n inputEdge(node: InputNode | undefined, fieldName: string): InputEdge | undefined {\n if (!node) {\n return undefined\n }\n\n const nodeData = this.#data.inputNodes[node.id]\n if (!nodeData) {\n return undefined\n }\n\n const fieldIndex = this.#stringIndex.get(fieldName)\n if (fieldIndex === undefined) {\n return undefined\n }\n\n const edge = nodeData.edges[fieldIndex]\n if (!edge) {\n return undefined\n }\n\n return {\n flags: edge.flags,\n childNodeId: edge.childNodeId,\n scalarMask: edge.scalarMask ?? 0,\n enumNameIndex: edge.enumNameIndex,\n }\n }\n\n /**\n * Get an output edge for a field name within a node.\n */\n outputEdge(node: OutputNode | undefined, fieldName: string): OutputEdge | undefined {\n if (!node) {\n return undefined\n }\n\n const nodeData = this.#data.outputNodes[node.id]\n if (!nodeData) {\n return undefined\n }\n\n const fieldIndex = this.#stringIndex.get(fieldName)\n if (fieldIndex === undefined) {\n return undefined\n }\n\n const edge = nodeData.edges[fieldIndex]\n if (!edge) {\n return undefined\n }\n\n return {\n argsNodeId: edge.argsNodeId,\n outputNodeId: edge.outputNodeId,\n }\n }\n\n /**\n * Get enum values for an edge that references a user enum.\n * Returns undefined if the edge doesn't reference an enum.\n */\n enumValues(edge: InputEdge | undefined): readonly string[] | undefined {\n if (edge?.enumNameIndex === undefined) {\n return undefined\n }\n\n const enumName = this.#data.strings[edge.enumNameIndex]\n if (!enumName) {\n return undefined\n }\n\n return this.#enumLookup(enumName)\n }\n\n /**\n * Get a string from the string table by index.\n */\n getString(index: number): string | undefined {\n return this.#data.strings[index]\n }\n}\n\n/**\n * Bit flags for InputEdge.flags describing what the field accepts.\n */\nexport const EdgeFlag = {\n /**\n * Field may be parameterized as a scalar value.\n * Check ScalarMask to validate the value type.\n */\n ParamScalar: 1,\n\n /**\n * Field may be parameterized as an enum.\n * Check enum ID to validate the value type.\n */\n ParamEnum: 2,\n\n /**\n * Field accepts list-of-scalar values.\n * Parameterize the whole list if all elements match ScalarMask.\n */\n ParamListScalar: 4,\n\n /**\n * Field accepts list-of-enum values.\n * Parameterize the whole list if all elements match enum ID.\n */\n ParamListEnum: 8,\n\n /**\n * Field accepts list-of-object values.\n * Recurse into each element using the child node.\n */\n ListObject: 16,\n\n /**\n * Field accepts object values.\n * Recurse into child input node.\n */\n Object: 32,\n} as const\n\nexport type EdgeFlagValue = (typeof EdgeFlag)[keyof typeof EdgeFlag]\n\n/**\n * Bit mask for scalar type categories.\n * Used in InputEdge.scalarMask to validate runtime value types.\n */\nexport const ScalarMask = {\n String: 1,\n Int: 2,\n BigInt: 4,\n Float: 8,\n Decimal: 16,\n Boolean: 32,\n DateTime: 64,\n Json: 128,\n Bytes: 256,\n} as const\n\nexport type ScalarMaskValue = (typeof ScalarMask)[keyof typeof ScalarMask]\n\n/**\n * Helper function to check if an edge has a specific flag.\n */\nexport function hasFlag(edge: InputEdge, flag: number): boolean {\n return (edge.flags & flag) !== 0\n}\n\n/**\n * Helper function to get the scalar mask from an edge.\n */\nexport function getScalarMask(edge: InputEdge): number {\n return edge.scalarMask\n}\n\n/**\n * Maps DMMF scalar type names to ScalarMask values.\n */\nexport function scalarTypeToMask(typeName: string): number {\n switch (typeName) {\n case 'String':\n case 'UUID':\n return ScalarMask.String\n case 'Int':\n return ScalarMask.Int\n case 'BigInt':\n return ScalarMask.BigInt\n case 'Float':\n return ScalarMask.Float\n case 'Decimal':\n return ScalarMask.Decimal\n case 'Boolean':\n return ScalarMask.Boolean\n case 'DateTime':\n return ScalarMask.DateTime\n case 'Json':\n return ScalarMask.Json\n case 'Bytes':\n return ScalarMask.Bytes\n default:\n return 0\n }\n}\n\n// Re-export data types for builder use\nexport type { InputEdgeData, InputNodeData, OutputEdgeData, OutputNodeData, ParamGraphData, RootEntryData }\n", "{\n \"name\": \"@prisma/client\",\n \"version\": \"7.4.0-integration-parameterization.19\",\n \"description\": \"Prisma Client is an auto-generated, type-safe and modern JavaScript/TypeScript ORM for Node.js that's tailored to your data. Supports PostgreSQL, CockroachDB, MySQL, MariaDB, SQL Server, SQLite & MongoDB databases.\",\n \"keywords\": [\n \"ORM\",\n \"Prisma\",\n \"prisma2\",\n \"Prisma Client\",\n \"client\",\n \"query\",\n \"query-builder\",\n \"database\",\n \"db\",\n \"JavaScript\",\n \"JS\",\n \"TypeScript\",\n \"TS\",\n \"SQL\",\n \"SQLite\",\n \"pg\",\n \"Postgres\",\n \"PostgreSQL\",\n \"CockroachDB\",\n \"MySQL\",\n \"MariaDB\",\n \"MSSQL\",\n \"SQL Server\",\n \"SQLServer\",\n \"MongoDB\"\n ],\n \"main\": \"default.js\",\n \"types\": \"default.d.ts\",\n \"browser\": \"index-browser.js\",\n \"exports\": {\n \"./package.json\": \"./package.json\",\n \".\": {\n \"require\": {\n \"types\": \"./default.d.ts\",\n \"node\": \"./default.js\",\n \"edge-light\": \"./default.js\",\n \"workerd\": \"./default.js\",\n \"worker\": \"./default.js\",\n \"browser\": \"./index-browser.js\"\n },\n \"import\": {\n \"types\": \"./default.d.ts\",\n \"node\": \"./default.js\",\n \"edge-light\": \"./default.js\",\n \"workerd\": \"./default.js\",\n \"worker\": \"./default.js\",\n \"browser\": \"./index-browser.js\"\n },\n \"default\": \"./default.js\"\n },\n \"./extension\": {\n \"types\": \"./extension.d.ts\",\n \"require\": \"./extension.js\",\n \"import\": \"./extension.js\",\n \"default\": \"./extension.js\"\n },\n \"./index-browser\": {\n \"types\": \"./index.d.ts\",\n \"require\": \"./index-browser.js\",\n \"import\": \"./index-browser.js\",\n \"default\": \"./index-browser.js\"\n },\n \"./index\": {\n \"types\": \"./index.d.ts\",\n \"require\": \"./index.js\",\n \"import\": \"./index.js\",\n \"default\": \"./index.js\"\n },\n \"./edge\": {\n \"types\": \"./edge.d.ts\",\n \"require\": \"./edge.js\",\n \"import\": \"./edge.js\",\n \"default\": \"./edge.js\"\n },\n \"./runtime/client\": {\n \"types\": \"./runtime/client.d.ts\",\n \"node\": {\n \"require\": \"./runtime/client.js\",\n \"default\": \"./runtime/client.js\"\n },\n \"require\": \"./runtime/client.js\",\n \"import\": \"./runtime/client.mjs\",\n \"default\": \"./runtime/client.mjs\"\n },\n \"./runtime/wasm-compiler-edge\": {\n \"types\": \"./runtime/wasm-compiler-edge.d.ts\",\n \"require\": \"./runtime/wasm-compiler-edge.js\",\n \"import\": \"./runtime/wasm-compiler-edge.mjs\",\n \"default\": \"./runtime/wasm-compiler-edge.mjs\"\n },\n \"./runtime/index-browser\": {\n \"types\": \"./runtime/index-browser.d.ts\",\n \"require\": \"./runtime/index-browser.js\",\n \"import\": \"./runtime/index-browser.mjs\",\n \"default\": \"./runtime/index-browser.mjs\"\n },\n \"./generator-build\": {\n \"require\": \"./generator-build/index.js\",\n \"import\": \"./generator-build/index.js\",\n \"default\": \"./generator-build/index.js\"\n },\n \"./sql\": {\n \"require\": {\n \"types\": \"./sql.d.ts\",\n \"node\": \"./sql.js\",\n \"default\": \"./sql.js\"\n },\n \"import\": {\n \"types\": \"./sql.d.ts\",\n \"node\": \"./sql.mjs\",\n \"default\": \"./sql.mjs\"\n },\n \"default\": \"./sql.js\"\n },\n \"./*\": \"./*\"\n },\n \"license\": \"Apache-2.0\",\n \"engines\": {\n \"node\": \"^20.19 || ^22.12 || >=24.0\"\n },\n \"homepage\": \"https://www.prisma.io\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/prisma/prisma.git\",\n \"directory\": \"packages/client\"\n },\n \"author\": \"Tim Suchanek <suchanek@prisma.io>\",\n \"bugs\": \"https://github.com/prisma/prisma/issues\",\n \"scripts\": {\n \"dev\": \"DEV=true tsx helpers/build.ts\",\n \"build\": \"tsx helpers/build.ts\",\n \"test\": \"dotenv -e ../../.db.env -- jest --silent\",\n \"test:e2e\": \"dotenv -e ../../.db.env -- tsx tests/e2e/_utils/run.ts\",\n \"test:functional\": \"dotenv -e ../../.db.env -- tsx helpers/functional-test/run-tests.ts\",\n \"test:functional:client\": \"pnpm run test:functional --client-runtime client\",\n \"test:memory\": \"dotenv -e ../../.db.env -- tsx helpers/memory-tests.ts\",\n \"test:functional:code\": \"dotenv -e ../../.db.env -- tsx helpers/functional-test/run-tests.ts --no-types\",\n \"test:functional:types\": \"dotenv -e ../../.db.env -- tsx helpers/functional-test/run-tests.ts --types-only\",\n \"test-notypes\": \"dotenv -e ../../.db.env -- jest --testPathIgnorePatterns src/__tests__/types/types.test.ts\",\n \"prepublishOnly\": \"pnpm run build\",\n \"new-test\": \"tsx ./helpers/new-test/new-test.ts\"\n },\n \"files\": [\n \"README.md\",\n \"runtime\",\n \"scripts\",\n \"generator-build\",\n \"edge.js\",\n \"edge.d.ts\",\n \"index.js\",\n \"index.d.ts\",\n \"default.js\",\n \"default.d.ts\",\n \"index-browser.js\",\n \"extension.js\",\n \"extension.d.ts\",\n \"sql.d.ts\",\n \"sql.js\",\n \"sql.mjs\"\n ],\n \"devDependencies\": {\n \"@cloudflare/workers-types\": \"^4.20251014.0\",\n \"@codspeed/benchmark.js-plugin\": \"4.0.0\",\n \"@faker-js/faker\": \"9.6.0\",\n \"@fast-check/jest\": \"2.0.3\",\n \"@hono/node-server\": \"1.19.0\",\n \"@inquirer/prompts\": \"7.3.3\",\n \"@jest/create-cache-key-function\": \"29.7.0\",\n \"@jest/globals\": \"29.7.0\",\n \"@jest/test-sequencer\": \"29.7.0\",\n \"@libsql/client\": \"0.8.1\",\n \"@neondatabase/serverless\": \"0.10.2\",\n \"@opentelemetry/api\": \"1.9.0\",\n \"@opentelemetry/context-async-hooks\": \"2.1.0\",\n \"@opentelemetry/instrumentation\": \"0.206.0\",\n \"@opentelemetry/resources\": \"2.1.0\",\n \"@opentelemetry/sdk-trace-base\": \"2.1.0\",\n \"@opentelemetry/semantic-conventions\": \"1.37.0\",\n \"@planetscale/database\": \"1.19.0\",\n \"@prisma/adapter-better-sqlite3\": \"workspace:*\",\n \"@prisma/adapter-d1\": \"workspace:*\",\n \"@prisma/adapter-libsql\": \"workspace:*\",\n \"@prisma/adapter-mariadb\": \"workspace:*\",\n \"@prisma/adapter-mssql\": \"workspace:*\",\n \"@prisma/adapter-neon\": \"workspace:*\",\n \"@prisma/adapter-pg\": \"workspace:*\",\n \"@prisma/adapter-planetscale\": \"workspace:*\",\n \"@prisma/client-common\": \"workspace:*\",\n \"@prisma/client-engine-runtime\": \"workspace:*\",\n \"@prisma/client-generator-js\": \"workspace:*\",\n \"@prisma/client-generator-ts\": \"workspace:*\",\n \"@prisma/config\": \"workspace:*\",\n \"@prisma/debug\": \"workspace:*\",\n \"@prisma/dmmf\": \"workspace:*\",\n \"@prisma/driver-adapter-utils\": \"workspace:*\",\n \"@prisma/engines\": \"workspace:*\",\n \"@prisma/engines-version\": \"7.4.0-8.534ac5c12b9088d160899554cc8c11039ffb9738\",\n \"@prisma/fetch-engine\": \"workspace:*\",\n \"@prisma/generator\": \"workspace:*\",\n \"@prisma/generator-helper\": \"workspace:*\",\n \"@prisma/get-platform\": \"workspace:*\",\n \"@prisma/instrumentation\": \"workspace:*\",\n \"@prisma/instrumentation-contract\": \"workspace:*\",\n \"@prisma/internals\": \"workspace:*\",\n \"@prisma/json-protocol\": \"workspace:*\",\n \"@prisma/migrate\": \"workspace:*\",\n \"@prisma/query-compiler-wasm\": \"7.4.0-8.534ac5c12b9088d160899554cc8c11039ffb9738\",\n \"@prisma/param-graph\": \"workspace:*\",\n \"@prisma/param-graph-builder\": \"workspace:*\",\n \"@prisma/query-plan-executor\": \"workspace:*\",\n \"@prisma/sqlcommenter\": \"workspace:*\",\n \"@prisma/sqlcommenter-trace-context\": \"workspace:*\",\n \"@prisma/ts-builders\": \"workspace:*\",\n \"@snaplet/copycat\": \"6.0.0\",\n \"@swc-node/register\": \"1.10.9\",\n \"@swc/core\": \"1.11.5\",\n \"@swc/jest\": \"0.2.37\",\n \"@timsuchanek/copy\": \"1.4.5\",\n \"@types/debug\": \"4.1.12\",\n \"@types/fs-extra\": \"11.0.4\",\n \"@types/jest\": \"29.5.14\",\n \"@types/js-levenshtein\": \"1.1.3\",\n \"@types/mssql\": \"9.1.8\",\n \"@types/node\": \"~20.19.24\",\n \"@types/pg\": \"8.11.11\",\n \"arg\": \"5.0.2\",\n \"benchmark\": \"2.1.4\",\n \"cookie-es\": \"2.0.0\",\n \"execa\": \"8.0.1\",\n \"expect-type\": \"1.2.2\",\n \"fs-extra\": \"11.3.0\",\n \"get-stream\": \"6.0.1\",\n \"globby\": \"11.1.0\",\n \"indent-string\": \"4.0.0\",\n \"jest\": \"29.7.0\",\n \"jest-extended\": \"4.0.2\",\n \"jest-junit\": \"16.0.0\",\n \"jest-serializer-ansi-escapes\": \"4.0.0\",\n \"jest-snapshot\": \"29.7.0\",\n \"js-levenshtein\": \"1.1.6\",\n \"kleur\": \"4.1.5\",\n \"klona\": \"2.0.6\",\n \"mariadb\": \"3.4.5\",\n \"memfs\": \"4.17.2\",\n \"mssql\": \"11.0.1\",\n \"new-github-issue-url\": \"0.2.1\",\n \"p-retry\": \"4.6.2\",\n \"pg\": \"8.14.1\",\n \"resolve\": \"1.22.10\",\n \"simple-statistics\": \"7.8.8\",\n \"sort-keys\": \"5.1.0\",\n \"source-map-support\": \"0.5.21\",\n \"stacktrace-parser\": \"0.1.11\",\n \"strip-ansi\": \"7.1.0\",\n \"strip-indent\": \"4.0.0\",\n \"tempy\": \"3.0.0\",\n \"ts-pattern\": \"5.6.2\",\n \"tsd\": \"0.31.2\",\n \"typescript\": \"5.4.5\",\n \"undici\": \"7.4.0\",\n \"zx\": \"8.4.1\"\n },\n \"dependencies\": {\n \"@prisma/client-runtime-utils\": \"workspace:*\"\n },\n \"peerDependencies\": {\n \"prisma\": \"*\",\n \"typescript\": \">=5.4.0\"\n },\n \"peerDependenciesMeta\": {\n \"prisma\": {\n \"optional\": true\n },\n \"typescript\": {\n \"optional\": true\n }\n },\n \"sideEffects\": false\n}", "import type { PrismaValue } from '@prisma/client-engine-runtime'\nimport type { ArgScalarType, ArgType } from '@prisma/driver-adapter-utils'\n\ntype RawParameters = {\n args: PrismaValue[]\n argTypes: ArgType[]\n}\n\nconst tagToArgScalarType: Record<string, ArgScalarType> = {\n bigint: 'bigint',\n date: 'datetime',\n decimal: 'decimal',\n bytes: 'bytes',\n}\n\nexport function deserializeRawParameters(serializedParameters: string): RawParameters {\n let parsed: unknown\n try {\n parsed = JSON.parse(serializedParameters)\n } catch (err) {\n throw new Error(`Received invalid serialized parameters: ${err.message}`)\n }\n if (!Array.isArray(parsed)) {\n throw new Error('Received invalid serialized parameters: expected an array')\n }\n const args = parsed.map((parameter: unknown) => decodeParameter(parameter))\n const argTypes = parsed.map((parameter: unknown) => getArgType(parameter))\n return { args, argTypes }\n}\n\nfunction decodeParameter(parameter: unknown): PrismaValue {\n if (Array.isArray(parameter)) {\n return parameter.map((item) => decodeParameter(item))\n }\n\n if (typeof parameter === 'object' && parameter !== null && 'prisma__value' in parameter) {\n if (!('prisma__type' in parameter)) {\n throw new Error('Invalid serialized parameter, prisma__type should be present when prisma__value is present')\n }\n return `${parameter.prisma__value}`\n }\n\n if (typeof parameter === 'object' && parameter !== null) {\n return JSON.stringify(parameter)\n }\n\n return parameter as PrismaValue\n}\n\nfunction getArgType(parameter: unknown): ArgType {\n if (Array.isArray(parameter)) {\n return { scalarType: parameter.length > 0 ? getScalarType(parameter[0]) : 'unknown', arity: 'list' }\n }\n\n return { scalarType: getScalarType(parameter), arity: 'scalar' }\n}\n\nfunction getScalarType(parameter: unknown): ArgScalarType {\n if (\n typeof parameter === 'object' &&\n parameter !== null &&\n 'prisma__type' in parameter &&\n typeof parameter.prisma__type === 'string' &&\n parameter.prisma__type in tagToArgScalarType\n ) {\n return tagToArgScalarType[parameter.prisma__type]\n }\n\n if (typeof parameter === 'number') {\n return 'decimal'\n }\n\n if (typeof parameter === 'string') {\n return 'string'\n }\n\n return 'unknown'\n}\n", "import type { JsonBatchQuery, JsonQuery } from '@prisma/json-protocol'\n\nimport { TransactionOptions } from '../Engine'\n\nexport function getBatchRequestPayload(batch: JsonQuery[], transaction?: TransactionOptions<unknown>): JsonBatchQuery {\n return {\n batch,\n transaction: transaction?.kind === 'batch' ? { isolationLevel: transaction.options.isolationLevel } : undefined,\n }\n}\n", "export function maskQuery(query?: string): string {\n if (!query) {\n return ''\n }\n return (\n query\n // replace all strings with X\n .replace(/\".*\"/g, '\"X\"')\n // replace all numbers with 5\n .replace(/[\\s:\\[]([+-]?([0-9]*[.])?[0-9]+)/g, (substr) => {\n return `${substr[0]}5`\n })\n )\n}\n", "/**\n * Removes the leading timestamps (from docker) and trailing ms (from debug)\n * @param logs logs to normalize\n */\nexport function normalizeLogs(logs: string): string {\n return logs\n .split('\\n')\n .map((l) => {\n return l\n .replace(/^\\d{4}-[01]\\d-[0-3]\\dT[0-2]\\d:[0-5]\\d:[0-5]\\d\\.\\d+([+-][0-2]\\d:[0-5]\\d|Z)\\s*/, '')\n .replace(/\\+\\d+\\s*ms$/, '')\n })\n .join('\\n')\n}\n", "import newGitHubIssueUrl from 'new-github-issue-url'\n\nexport function getGitHubIssueUrl({\n title,\n user = 'prisma',\n repo = 'prisma',\n template = 'bug_report.yml',\n body,\n}: {\n title: string\n user?: string\n repo?: string\n template?: string\n body?: string\n}): string {\n return newGitHubIssueUrl({\n user,\n repo,\n template,\n title,\n body,\n })\n}\n", "import { getLogs } from '@prisma/debug'\nimport { underline } from 'kleur/colors'\nimport stripAnsi from 'strip-ansi'\n\nimport type { ErrorWithLinkInput } from '../types/ErrorWithLinkInput'\nimport { maskQuery } from './maskQuery'\nimport { normalizeLogs } from './normalizeLogs'\nimport { getGitHubIssueUrl } from './util'\n\nexport function getErrorMessageWithLink({\n version,\n binaryTarget,\n title,\n description,\n engineVersion,\n database,\n query,\n}: ErrorWithLinkInput) {\n const gotLogs = getLogs(6000 - (query?.length ?? 0))\n const logs = normalizeLogs(stripAnsi(gotLogs))\n const moreInfo = description ? `# Description\\n\\`\\`\\`\\n${description}\\n\\`\\`\\`` : ''\n const body = stripAnsi(\n `Hi Prisma Team! My Prisma Client just crashed. This is the report:\n## Versions\n\n| Name | Version |\n|-----------------|--------------------|\n| Node | ${process.version?.padEnd(19)}| \n| OS | ${binaryTarget?.padEnd(19)}|\n| Prisma Client | ${version?.padEnd(19)}|\n| Query Engine | ${engineVersion?.padEnd(19)}|\n| Database | ${database?.padEnd(19)}|\n\n${moreInfo}\n\n## Logs\n\\`\\`\\`\n${logs}\n\\`\\`\\`\n\n## Client Snippet\n\\`\\`\\`ts\n// PLEASE FILL YOUR CODE SNIPPET HERE\n\\`\\`\\`\n\n## Schema\n\\`\\`\\`prisma\n// PLEASE ADD YOUR SCHEMA HERE IF POSSIBLE\n\\`\\`\\`\n\n## Prisma Engine Query\n\\`\\`\\`\n${query ? maskQuery(query) : ''}\n\\`\\`\\`\n`,\n )\n\n const url = getGitHubIssueUrl({ title, body })\n return `${title}\n\nThis is a non-recoverable error which probably happens when the Prisma Query Engine has a panic.\n\n${underline(url)}\n\nIf you want the Prisma team to look into it, please open the link above \uD83D\uDE4F\nTo increase the chance of success, please post your schema and a snippet of\nhow you used Prisma Client in the issue. \n`\n}\n", "import {\n type QueryEvent,\n QueryInterpreter,\n type SchemaProvider,\n type TracingHelper,\n TransactionManager,\n type TransactionOptions,\n} from '@prisma/client-engine-runtime'\nimport type { ConnectionInfo, SqlDriverAdapter, SqlDriverAdapterFactory } from '@prisma/driver-adapter-utils'\nimport type { SqlCommenterPlugin } from '@prisma/sqlcommenter'\n\nimport type { InteractiveTransactionInfo } from '../common/types/Transaction'\nimport type { ExecutePlanParams, Executor, ProviderAndConnectionInfo } from './Executor'\n\nexport interface LocalExecutorOptions {\n driverAdapterFactory: SqlDriverAdapterFactory\n transactionOptions: TransactionOptions\n tracingHelper: TracingHelper\n onQuery?: (event: QueryEvent) => void\n provider?: SchemaProvider\n sqlCommenters?: SqlCommenterPlugin[]\n}\n\nexport class LocalExecutor implements Executor {\n readonly #options: LocalExecutorOptions\n readonly #driverAdapter: SqlDriverAdapter\n readonly #transactionManager: TransactionManager\n readonly #connectionInfo?: ConnectionInfo\n readonly #interpreter: QueryInterpreter\n\n constructor(options: LocalExecutorOptions, driverAdapter: SqlDriverAdapter, transactionManager: TransactionManager) {\n this.#options = options\n this.#driverAdapter = driverAdapter\n this.#transactionManager = transactionManager\n this.#connectionInfo = driverAdapter.getConnectionInfo?.()\n this.#interpreter = QueryInterpreter.forSql({\n onQuery: this.#options.onQuery,\n tracingHelper: this.#options.tracingHelper,\n provider: this.#options.provider,\n connectionInfo: this.#connectionInfo,\n })\n }\n\n static async connect(options: LocalExecutorOptions): Promise<LocalExecutor> {\n let driverAdapter: SqlDriverAdapter | undefined = undefined\n let transactionManager: TransactionManager | undefined = undefined\n\n try {\n driverAdapter = await options.driverAdapterFactory.connect()\n transactionManager = new TransactionManager({\n driverAdapter,\n transactionOptions: options.transactionOptions,\n tracingHelper: options.tracingHelper,\n onQuery: options.onQuery,\n provider: options.provider,\n })\n } catch (error) {\n await driverAdapter?.dispose()\n throw error\n }\n\n return new LocalExecutor(options, driverAdapter, transactionManager)\n }\n\n getConnectionInfo(): Promise<ProviderAndConnectionInfo> {\n const connectionInfo = this.#connectionInfo ?? { supportsRelationJoins: false }\n return Promise.resolve({ provider: this.#driverAdapter.provider, connectionInfo })\n }\n\n async execute({\n plan,\n placeholderValues: scope,\n transaction,\n batchIndex,\n queryInfo,\n }: ExecutePlanParams): Promise<unknown> {\n const queryable = transaction\n ? await this.#transactionManager.getTransaction(transaction, batchIndex !== undefined ? 'batch query' : 'query')\n : this.#driverAdapter\n\n return await this.#interpreter.run(plan, {\n queryable,\n transactionManager: transaction ? { enabled: false } : { enabled: true, manager: this.#transactionManager },\n scope,\n sqlCommenter: this.#options.sqlCommenters && {\n plugins: this.#options.sqlCommenters,\n queryInfo,\n },\n })\n }\n\n async startTransaction(options: TransactionOptions): Promise<InteractiveTransactionInfo> {\n return { ...(await this.#transactionManager.startTransaction(options)), payload: undefined }\n }\n\n async commitTransaction(transaction: InteractiveTransactionInfo): Promise<void> {\n await this.#transactionManager.commitTransaction(transaction.id)\n }\n\n async rollbackTransaction(transaction: InteractiveTransactionInfo): Promise<void> {\n await this.#transactionManager.rollbackTransaction(transaction.id)\n }\n\n async disconnect(): Promise<void> {\n try {\n await this.#transactionManager.cancelAllTransactions()\n } finally {\n await this.#driverAdapter.dispose()\n }\n }\n\n apiKey(): string | null {\n return null\n }\n}\n", "/**\n * Value classification for parameterization.\n *\n * This module classifies runtime values into categories before applying\n * schema rules during parameterization.\n */\n\nimport { JsonInputTaggedValue } from '@prisma/json-protocol'\n\n/**\n * Tagged value types that represent scalar values.\n * These can be parameterized when the schema allows.\n */\nconst SCALAR_TAGS = new Set(['DateTime', 'Decimal', 'BigInt', 'Bytes', 'Json', 'Raw'])\n\n/**\n * Tagged value types that are structural and should never be parameterized.\n * These represent special query constructs that must be preserved as-is.\n */\nconst STRUCTURAL_TAGS = new Set(['FieldRef', 'Enum', 'Param'])\n\n/**\n * Classification result for a runtime value.\n * Used to determine how to handle the value during parameterization.\n */\nexport type ValueClass =\n | { kind: 'null' }\n | { kind: 'primitive'; value: string | number | boolean }\n | { kind: 'taggedScalar'; tag: JsonInputTaggedValue['$type']; value: unknown }\n | { kind: 'structural'; value: unknown }\n | { kind: 'array'; items: unknown[] }\n | { kind: 'object'; entries: Record<string, unknown> }\n\n/**\n * Classifies a runtime value for parameterization purposes.\n *\n * @param value - The value to classify\n * @returns The classification result indicating how to handle the value\n */\nexport function classifyValue(value: unknown): ValueClass {\n if (value === null || value === undefined) {\n return { kind: 'null' }\n }\n\n if (typeof value === 'string') {\n return { kind: 'primitive', value }\n }\n if (typeof value === 'number') {\n return { kind: 'primitive', value }\n }\n if (typeof value === 'boolean') {\n return { kind: 'primitive', value }\n }\n\n if (Array.isArray(value)) {\n return { kind: 'array', items: value }\n }\n\n if (typeof value === 'object') {\n const obj = value as Record<string, unknown>\n\n // Check for tagged value\n if ('$type' in obj && typeof obj.$type === 'string') {\n const tag = obj.$type as JsonInputTaggedValue['$type']\n\n if (SCALAR_TAGS.has(tag)) {\n return { kind: 'taggedScalar', tag, value: obj.value }\n }\n\n if (STRUCTURAL_TAGS.has(tag)) {\n return { kind: 'structural', value: obj.value }\n }\n }\n\n return { kind: 'object', entries: obj }\n }\n\n return { kind: 'structural', value }\n}\n\n/**\n * Checks if a value is a plain object (not a tagged value or array).\n */\nexport function isPlainObject(value: unknown): value is Record<string, unknown> {\n return (\n typeof value === 'object' &&\n value !== null &&\n !Array.isArray(value) &&\n !('$type' in (value as Record<string, unknown>))\n )\n}\n\n/**\n * Checks if a value is a tagged value with a $type property.\n */\nexport function isTaggedValue(value: unknown): value is { $type: string; value: unknown } {\n return (\n typeof value === 'object' &&\n value !== null &&\n '$type' in value &&\n typeof (value as { $type: unknown }).$type === 'string'\n )\n}\n", "/**\n * Schema-aware traversal algorithm for parameterization.\n *\n * This module implements the core parameterization logic that walks the\n * JsonQuery tree guided by ParamGraph. It only parameterizes values when\n * both schema rules and runtime value types agree.\n */\n\nimport type {\n JsonArgumentValue,\n JsonBatchQuery,\n JsonFieldSelection,\n JsonInputTaggedValue,\n JsonQuery,\n JsonSelectionSet,\n PlaceholderTaggedValue,\n} from '@prisma/json-protocol'\nimport { PlaceholderType } from '@prisma/json-protocol'\nimport type { InputEdge, InputNode } from '@prisma/param-graph'\nimport { EdgeFlag, getScalarMask, hasFlag, ParamGraph, ScalarMask } from '@prisma/param-graph'\n\nimport { classifyValue, isPlainObject, isTaggedValue, ValueClass } from './classify'\n\n/**\n * Result of parameterizing a single query.\n */\nexport interface ParameterizeResult {\n /** The query with user data values replaced by placeholders */\n parameterizedQuery: JsonQuery\n /** Map of placeholder names to their actual values */\n placeholderValues: Record<string, unknown>\n}\n\n/**\n * Result of parameterizing a batch of queries.\n */\nexport interface ParameterizeBatchResult {\n /** The batch with user data values replaced by placeholders */\n parameterizedBatch: JsonBatchQuery\n /** Combined map of placeholder names to their actual values */\n placeholderValues: Record<string, unknown>\n}\n\n/**\n * Parameterizes a single query using the schema-aware approach.\n *\n * @param query - The query to parameterize\n * @param view - The ParamGraph for schema lookups\n * @returns The parameterized query with extracted placeholder values\n */\nexport function parameterizeQuery(query: JsonQuery, view: ParamGraph): ParameterizeResult {\n const parameterizer = new Parameterizer(view)\n\n const rootKey = query.modelName ? `${query.modelName}.${query.action}` : query.action\n const root = view.root(rootKey)\n\n const parameterizedQuery: JsonQuery = {\n ...query,\n query: parameterizer.parameterizeFieldSelection(query.query, root?.argsNodeId, root?.outputNodeId),\n }\n\n return {\n parameterizedQuery,\n placeholderValues: parameterizer.getPlaceholderValues(),\n }\n}\n\n/**\n * Parameterizes a batch of queries using the schema-aware approach.\n *\n * @param batch - The batch to parameterize\n * @param view - The ParamGraph for schema lookups\n * @returns The parameterized batch with extracted placeholder values\n */\nexport function parameterizeBatch(batch: JsonBatchQuery, view: ParamGraph): ParameterizeBatchResult {\n const parameterizer = new Parameterizer(view)\n const parameterizedQueries: JsonQuery[] = []\n\n for (let i = 0; i < batch.batch.length; i++) {\n const query = batch.batch[i]\n\n const rootKey = query.modelName ? `${query.modelName}.${query.action}` : query.action\n const root = view.root(rootKey)\n\n parameterizedQueries.push({\n ...query,\n query: parameterizer.parameterizeFieldSelection(query.query, root?.argsNodeId, root?.outputNodeId),\n })\n }\n\n return {\n parameterizedBatch: { ...batch, batch: parameterizedQueries },\n placeholderValues: parameterizer.getPlaceholderValues(),\n }\n}\n\n/**\n * Encapsulates the state and logic for parameterizing queries.\n */\nclass Parameterizer {\n readonly #view: ParamGraph\n readonly #placeholders = new Map<string, unknown>()\n readonly #valueToPlaceholder = new Map<string, string>()\n #nextPlaceholderId = 1\n\n constructor(view: ParamGraph) {\n this.#view = view\n }\n\n /**\n * Returns the collected placeholder values as a plain object.\n */\n getPlaceholderValues(): Record<string, unknown> {\n return Object.fromEntries(this.#placeholders)\n }\n\n /**\n * Gets or creates a placeholder for the given value.\n * If a placeholder already exists for this value, returns a reference to the existing name.\n * Otherwise, registers a new placeholder with a sequential name.\n * We reuse the placeholders for equal values because the query compiler needs to be able\n * to compare the values for equality for certain optimizations (at the time of writing,\n * only for deciding whether to use native or emulated upserts).\n */\n #getOrCreatePlaceholder(value: unknown, type: PlaceholderType): PlaceholderTaggedValue {\n const valueKey = createValueKey(value, type)\n const existingName = this.#valueToPlaceholder.get(valueKey)\n\n if (existingName !== undefined) {\n return createPlaceholder(existingName, type)\n }\n\n const name = `%${this.#nextPlaceholderId++}`\n this.#valueToPlaceholder.set(valueKey, name)\n this.#placeholders.set(name, value)\n return createPlaceholder(name, type)\n }\n\n /**\n * Parameterizes a field selection (arguments + selection).\n */\n parameterizeFieldSelection(\n sel: JsonFieldSelection,\n argsNodeId: number | undefined,\n outNodeId: number | undefined,\n ): JsonFieldSelection {\n const argsNode = this.#view.inputNode(argsNodeId)\n const outNode = this.#view.outputNode(outNodeId)\n\n const result: JsonFieldSelection = { ...sel }\n\n // Process arguments using input node\n if (sel.arguments && sel.arguments.$type !== 'Raw') {\n result.arguments = this.#parameterizeObject(sel.arguments as Record<string, unknown>, argsNode)\n }\n\n // Process selection using output node\n if (sel.selection) {\n result.selection = this.#parameterizeSelection(sel.selection, outNode)\n }\n\n return result\n }\n\n /**\n * Parameterizes an object by traversing its fields with the input node.\n */\n #parameterizeObject(obj: Record<string, unknown>, node: InputNode | undefined): Record<string, JsonArgumentValue> {\n if (!node) {\n // No parameterizable fields in this subtree - return as-is\n return obj as Record<string, JsonArgumentValue>\n }\n\n const result: Record<string, JsonArgumentValue> = {}\n\n for (const [key, value] of Object.entries(obj)) {\n const edge = this.#view.inputEdge(node, key)\n\n if (edge) {\n result[key] = this.#parameterizeValue(value, edge) as JsonArgumentValue\n } else {\n result[key] = value as JsonArgumentValue\n }\n }\n\n return result\n }\n\n /**\n * Core parameterization logic for a single value.\n */\n #parameterizeValue(value: unknown, edge: InputEdge): unknown {\n const classified = classifyValue(value)\n\n switch (classified.kind) {\n case 'null':\n // Null values are never parameterized - they affect query semantics\n return value\n\n case 'structural':\n return value\n\n case 'primitive':\n return this.#handlePrimitive(classified.value, edge)\n\n case 'taggedScalar':\n return this.#handleTaggedScalar(value as JsonInputTaggedValue, classified.tag, edge)\n\n case 'array':\n return this.#handleArray(classified.items, value, edge)\n\n case 'object':\n return this.#handleObject(classified.entries, edge)\n\n default:\n throw new Error(`Unknown value kind ${(classified satisfies never as ValueClass).kind}`)\n }\n }\n\n /**\n * Handles parameterization of primitive values (string, number, boolean).\n */\n #handlePrimitive(value: string | number | boolean, edge: InputEdge): JsonArgumentValue {\n if (hasFlag(edge, EdgeFlag.ParamEnum) && edge.enumNameIndex !== undefined && typeof value === 'string') {\n const enumValues = this.#view.enumValues(edge)\n if (enumValues?.includes(value)) {\n const type: PlaceholderType = { type: 'Enum' }\n return this.#getOrCreatePlaceholder(value, type)\n }\n }\n\n if (!hasFlag(edge, EdgeFlag.ParamScalar)) {\n return value\n }\n\n const mask = getScalarMask(edge)\n if (mask === 0) {\n return value\n }\n\n const type = getPrimitivePlaceholderType(value)\n if (!matchesPrimitiveMask(type, mask)) {\n return value\n }\n\n if (mask & ScalarMask.Json) {\n value = JSON.stringify(value)\n }\n\n return this.#getOrCreatePlaceholder(value, type)\n }\n\n /**\n * Handles parameterization of tagged scalar values (DateTime, Decimal, etc.).\n */\n #handleTaggedScalar(tagged: JsonInputTaggedValue, tag: JsonInputTaggedValue['$type'], edge: InputEdge): unknown {\n if (!hasFlag(edge, EdgeFlag.ParamScalar)) {\n return tagged\n }\n\n const mask = getScalarMask(edge)\n if (mask === 0 || !matchesTaggedMask(tag, mask)) {\n return tagged\n }\n\n const type = getTaggedPlaceholderType(tagged.$type)!\n const decoded = decodeTaggedValue(tagged)\n\n return this.#getOrCreatePlaceholder(decoded, type)\n }\n\n /**\n * Handles parameterization of array values.\n */\n #handleArray(items: unknown[], originalValue: unknown, edge: InputEdge): unknown {\n if (hasFlag(edge, EdgeFlag.ParamScalar) && getScalarMask(edge) & ScalarMask.Json) {\n const jsonValue = JSON.stringify(items)\n const type: PlaceholderType = { type: 'Json' }\n return this.#getOrCreatePlaceholder(jsonValue, type)\n }\n\n if (hasFlag(edge, EdgeFlag.ParamEnum)) {\n const enumValues = this.#view.enumValues(edge)\n if (enumValues && items.every((item) => typeof item === 'string' && enumValues.includes(item))) {\n const type: PlaceholderType = { type: 'List', inner: { type: 'Enum' } }\n return this.#getOrCreatePlaceholder(items, type)\n }\n }\n\n if (hasFlag(edge, EdgeFlag.ParamListScalar)) {\n const allValid = items.every((item) => validateListElement(item, edge))\n if (allValid && items.length > 0) {\n const decodedItems = items.map((item) => decodeIfTagged(item))\n const innerType = inferListElementType(items[0])\n const type: PlaceholderType = { type: 'List', inner: innerType }\n return this.#getOrCreatePlaceholder(decodedItems, type)\n }\n }\n\n if (hasFlag(edge, EdgeFlag.ListObject)) {\n const childNode = this.#view.inputNode(edge.childNodeId)\n if (childNode) {\n return items.map((item) => {\n if (isPlainObject(item)) {\n return this.#parameterizeObject(item, childNode)\n }\n return item\n })\n }\n }\n\n return originalValue\n }\n\n /**\n * Handles parameterization of object values.\n */\n #handleObject(obj: Record<string, unknown>, edge: InputEdge): unknown {\n if (hasFlag(edge, EdgeFlag.Object)) {\n const childNode = this.#view.inputNode(edge.childNodeId)\n if (childNode) {\n return this.#parameterizeObject(obj, childNode)\n }\n }\n\n const mask = getScalarMask(edge)\n if (mask & ScalarMask.Json) {\n const jsonValue = JSON.stringify(obj)\n const type: PlaceholderType = { type: 'Json' }\n return this.#getOrCreatePlaceholder(jsonValue, type)\n }\n\n return obj\n }\n\n /**\n * Parameterizes a selection set using output nodes.\n */\n #parameterizeSelection(selection: JsonSelectionSet, node: ReturnType<ParamGraph['outputNode']>): JsonSelectionSet {\n if (!selection || !node) {\n return selection\n }\n\n const result: JsonSelectionSet = {}\n\n for (const [key, value] of Object.entries(selection)) {\n if (key === '$scalars' || key === '$composites' || typeof value === 'boolean') {\n result[key] = value\n continue\n }\n\n const edge = this.#view.outputEdge(node, key)\n\n if (edge) {\n // Nested selection with possible args\n const nested = value as { arguments?: Record<string, unknown>; selection?: JsonSelectionSet }\n\n const argsNode = this.#view.inputNode(edge.argsNodeId)\n const childOutNode = this.#view.outputNode(edge.outputNodeId)\n\n const processedValue: JsonFieldSelection = {\n selection: nested.selection ? this.#parameterizeSelection(nested.selection, childOutNode) : {},\n }\n\n if (nested.arguments) {\n processedValue.arguments = this.#parameterizeObject(nested.arguments, argsNode)\n }\n\n result[key] = processedValue\n } else {\n result[key] = value\n }\n }\n\n return result\n }\n}\n\n/**\n * Creates a placeholder object with the given name.\n */\nfunction createPlaceholder(name: string, type: PlaceholderType): PlaceholderTaggedValue {\n return { $type: 'Param', value: { name, ...type } }\n}\n\n/**\n * Serializes a PlaceholderType to a string for use as part of a value key.\n */\nfunction serializePlaceholderType(type: PlaceholderType): string {\n if (type.type === 'List') {\n return `List<${serializePlaceholderType(type.inner)}>`\n }\n return type.type\n}\n\n/**\n * Serializes a value to a string for use as part of a value key.\n */\nfunction serializeValue(value: unknown): string {\n if (ArrayBuffer.isView(value)) {\n const bufView = Buffer.from(value.buffer, value.byteOffset, value.byteLength)\n return bufView.toString('base64')\n }\n return JSON.stringify(value)\n}\n\n/**\n * Creates a unique key for a (value, type) pair.\n * Used to detect when the same value appears multiple times.\n */\nfunction createValueKey(value: unknown, type: PlaceholderType): string {\n const typeKey = serializePlaceholderType(type)\n const valueKey = serializeValue(value)\n return `${typeKey}:${valueKey}`\n}\n\nconst MAX_INT = 2 ** 31 - 1\nconst MIN_INT = -(2 ** 31)\n\nfunction getPrimitivePlaceholderType(value: string | number | boolean): PlaceholderType {\n switch (typeof value) {\n case 'boolean':\n return { type: 'Boolean' }\n\n case 'number':\n if (!Number.isInteger(value)) {\n return { type: 'Float' }\n }\n if (MIN_INT <= value && value <= MAX_INT) {\n return { type: 'Int' }\n }\n return { type: 'BigInt' }\n\n case 'string':\n return { type: 'String' }\n\n default:\n throw new Error('unreachable')\n }\n}\n\n/**\n * Checks if a primitive value matches the scalar mask.\n */\nfunction matchesPrimitiveMask({ type }: PlaceholderType, mask: number): boolean {\n switch (type) {\n case 'Boolean':\n return (mask & ScalarMask.Boolean) !== 0\n case 'Int':\n return (mask & (ScalarMask.Int | ScalarMask.BigInt | ScalarMask.Float)) !== 0\n case 'BigInt':\n return (mask & ScalarMask.BigInt) !== 0\n case 'Float':\n return (mask & ScalarMask.Float) !== 0\n case 'String':\n return (mask & ScalarMask.String) !== 0\n default:\n return false\n }\n}\n\nfunction getTaggedPlaceholderType(tag: JsonInputTaggedValue['$type']): PlaceholderType | undefined {\n switch (tag) {\n case 'BigInt':\n case 'Bytes':\n case 'DateTime':\n case 'Json':\n return { type: tag }\n case 'Decimal':\n return { type: 'Float' }\n default:\n return undefined\n }\n}\n\n/**\n * Infers the placeholder type for an element in a list.\n * Used to determine the inner type of list placeholders.\n */\nfunction inferListElementType(item: unknown): PlaceholderType {\n const classified = classifyValue(item)\n\n switch (classified.kind) {\n case 'primitive':\n return getPrimitivePlaceholderType(classified.value)\n case 'taggedScalar': {\n const type = getTaggedPlaceholderType(classified.tag)\n return type ?? { type: 'Any' }\n }\n default:\n return { type: 'Any' }\n }\n}\n\n/**\n * Checks if a tagged scalar tag matches the scalar mask.\n */\nfunction matchesTaggedMask(tag: JsonInputTaggedValue['$type'], mask: number): boolean {\n switch (tag) {\n case 'DateTime':\n return (mask & ScalarMask.DateTime) !== 0\n case 'Decimal':\n return (mask & ScalarMask.Decimal) !== 0\n case 'BigInt':\n return (mask & ScalarMask.BigInt) !== 0\n case 'Bytes':\n return (mask & ScalarMask.Bytes) !== 0\n case 'Json':\n return (mask & ScalarMask.Json) !== 0\n default:\n return false\n }\n}\n\n/**\n * Validates that a list element can be parameterized.\n */\nfunction validateListElement(item: unknown, edge: InputEdge): boolean {\n const classified = classifyValue(item)\n\n switch (classified.kind) {\n case 'structural':\n return false\n\n case 'null':\n return false\n\n case 'primitive': {\n const type = getPrimitivePlaceholderType(classified.value)\n const mask = getScalarMask(edge)\n return mask !== 0 && matchesPrimitiveMask(type, mask)\n }\n\n case 'taggedScalar': {\n const mask = getScalarMask(edge)\n return mask !== 0 && matchesTaggedMask(classified.tag, mask)\n }\n\n default:\n return false\n }\n}\n\n/**\n * Decodes a value if it's a tagged scalar, otherwise returns as-is.\n */\nfunction decodeIfTagged(value: unknown): unknown {\n if (isTaggedValue(value)) {\n return decodeTaggedValue(value)\n }\n return value\n}\n\n/**\n * Decodes a tagged scalar value to its raw form.\n */\nfunction decodeTaggedValue(tagged: { $type: string; value: unknown }): unknown {\n return tagged.value\n}\n", "import type { BatchResponse, QueryPlanNode } from '@prisma/client-engine-runtime'\n\n// todo: store the query plan for the individual queries in a non-compacted batch\n// in the `#singleCache` so that it's possible to reuse them for compatible queries\n// outside of the batch in the future and avoid compiling them individually.\nexport class QueryPlanCache {\n readonly #singleCache: Map<string, QueryPlanNode>\n readonly #batchCache: Map<string, BatchResponse>\n readonly #maxSize: number\n\n constructor(maxSize = 1000) {\n this.#singleCache = new Map()\n this.#batchCache = new Map()\n this.#maxSize = maxSize\n }\n\n getSingle(key: string): QueryPlanNode | undefined {\n const entry = this.#singleCache.get(key)\n if (entry) {\n // Move to end for LRU behavior\n this.#singleCache.delete(key)\n this.#singleCache.set(key, entry)\n }\n return entry\n }\n\n setSingle(key: string, plan: QueryPlanNode): void {\n if (this.#singleCache.has(key)) {\n // Update existing entry (also moves to end for LRU)\n this.#singleCache.delete(key)\n this.#singleCache.set(key, plan)\n return\n }\n\n // Evict oldest if at capacity\n if (this.#singleCache.size >= this.#maxSize) {\n const firstKey = this.#singleCache.keys().next().value\n if (firstKey !== undefined) {\n this.#singleCache.delete(firstKey)\n }\n }\n\n this.#singleCache.set(key, plan)\n }\n\n getBatch(key: string): BatchResponse | undefined {\n const entry = this.#batchCache.get(key)\n if (entry) {\n // Move to end for LRU behavior\n this.#batchCache.delete(key)\n this.#batchCache.set(key, entry)\n }\n return entry\n }\n\n setBatch(key: string, response: BatchResponse): void {\n if (this.#batchCache.has(key)) {\n // Update existing entry (also moves to end for LRU)\n this.#batchCache.delete(key)\n this.#batchCache.set(key, response)\n return\n }\n\n // Evict oldest if at capacity\n if (this.#batchCache.size >= this.#maxSize) {\n const firstKey = this.#batchCache.keys().next().value\n if (firstKey !== undefined) {\n this.#batchCache.delete(firstKey)\n }\n }\n\n this.#batchCache.set(key, response)\n }\n\n clear(): void {\n this.#singleCache.clear()\n this.#batchCache.clear()\n }\n\n get size(): number {\n return this.#singleCache.size + this.#batchCache.size\n }\n\n get singleCacheSize(): number {\n return this.#singleCache.size\n }\n\n get batchCacheSize(): number {\n return this.#batchCache.size\n }\n}\n", "import type { QueryEngineLogLevel } from '@prisma/client-common'\nimport { applySqlCommenters, type TransactionOptions } from '@prisma/client-engine-runtime'\nimport { PrismaClientKnownRequestError } from '@prisma/client-runtime-utils'\nimport { Debug } from '@prisma/debug'\nimport type { EngineTraceEvent, TracingHelper } from '@prisma/instrumentation-contract'\nimport type { SqlCommenterPlugin } from '@prisma/sqlcommenter'\nimport { parseSetCookie, serialize as serializeCookie } from 'cookie-es'\n\nimport { getUrlAndApiKey } from '../accelerate/getUrlAndApiKey'\nimport { type AccelerateHeaders, HeaderBuilder } from '../accelerate/HeaderBuilder'\nimport type { AccelerateExtensionFetch } from '../common/Engine'\nimport type { LogEmitter } from '../common/types/Events'\nimport type { QueryEngineResultExtensions } from '../common/types/QueryEngine'\nimport type { InteractiveTransactionInfo } from '../common/types/Transaction'\nimport type { ExecutePlanParams, Executor, ProviderAndConnectionInfo } from './Executor'\nimport { dateFromEngineTimestamp } from './utils/engine-timestamp'\n\nconst debug = Debug('prisma:client:clientEngine:remoteExecutor')\n\nexport interface RemoteExecutorOptions {\n clientVersion: string\n logEmitter: LogEmitter\n logLevel: QueryEngineLogLevel\n logQueries: boolean\n tracingHelper: TracingHelper\n accelerateUrl: string\n sqlCommenters?: SqlCommenterPlugin[]\n}\n\nexport class RemoteExecutor implements Executor {\n readonly #clientVersion: string\n readonly #headerBuilder: HeaderBuilder\n readonly #httpClient: HttpClient\n readonly #logEmitter: LogEmitter\n readonly #tracingHelper: TracingHelper\n readonly #sqlCommenters?: SqlCommenterPlugin[]\n\n constructor(options: RemoteExecutorOptions) {\n this.#clientVersion = options.clientVersion\n this.#logEmitter = options.logEmitter\n this.#tracingHelper = options.tracingHelper\n this.#sqlCommenters = options.sqlCommenters\n\n const { url, apiKey } = getUrlAndApiKey({\n clientVersion: options.clientVersion,\n accelerateUrl: options.accelerateUrl,\n })\n\n this.#httpClient = new HttpClient(url)\n\n this.#headerBuilder = new HeaderBuilder({\n apiKey,\n engineHash: options.clientVersion,\n logLevel: options.logLevel,\n logQueries: options.logQueries,\n tracingHelper: options.tracingHelper,\n })\n }\n\n async getConnectionInfo(): Promise<ProviderAndConnectionInfo> {\n const connInfo = await this.#request({\n path: '/connection-info',\n method: 'GET',\n })\n return connInfo as ProviderAndConnectionInfo\n }\n\n async execute({\n plan,\n placeholderValues,\n batchIndex,\n model,\n operation,\n transaction,\n customFetch,\n queryInfo,\n }: ExecutePlanParams): Promise<unknown> {\n // Pre-compute comments from plugins\n const comments =\n queryInfo && this.#sqlCommenters?.length\n ? applySqlCommenters(this.#sqlCommenters, { query: queryInfo })\n : undefined\n\n const response = await this.#request({\n path: transaction ? `/transaction/${transaction.id}/query` : '/query',\n method: 'POST',\n body: {\n model,\n operation,\n plan,\n params: placeholderValues,\n // Send pre-computed comments to Query Plan Executor\n comments: comments && Object.keys(comments).length > 0 ? comments : undefined,\n },\n batchRequestIdx: batchIndex,\n fetch: customFetch,\n })\n\n return (response as Record<string, unknown>).data\n }\n\n async startTransaction(options: TransactionOptions): Promise<InteractiveTransactionInfo> {\n const txInfo = (await this.#request({\n path: '/transaction/start',\n method: 'POST',\n body: options,\n })) as { id: string }\n\n return { ...txInfo, payload: undefined }\n }\n\n async commitTransaction(transaction: InteractiveTransactionInfo): Promise<void> {\n await this.#request({\n path: `/transaction/${transaction.id}/commit`,\n method: 'POST',\n })\n }\n\n async rollbackTransaction(transaction: InteractiveTransactionInfo): Promise<void> {\n await this.#request({\n path: `/transaction/${transaction.id}/rollback`,\n method: 'POST',\n })\n }\n\n disconnect(): Promise<void> {\n return Promise.resolve()\n }\n\n apiKey(): string | null {\n return this.#headerBuilder.apiKey\n }\n\n async #request({\n path,\n method,\n body,\n fetch = globalThis.fetch,\n batchRequestIdx,\n }: {\n path: string\n method: string\n body?: unknown\n fetch?: AccelerateExtensionFetch\n batchRequestIdx?: number\n }): Promise<unknown> {\n const response = await this.#httpClient.request({\n method,\n path,\n headers: this.#headerBuilder.build(),\n body,\n fetch,\n })\n\n if (!response.ok) {\n await this.#throwErrorFromResponse(response, batchRequestIdx)\n }\n\n const responseJson = await response.json()\n\n if (typeof responseJson.extensions === 'object' && responseJson.extensions !== null) {\n this.#processExtensions(responseJson.extensions as QueryEngineResultExtensions)\n }\n\n return responseJson\n }\n\n async #throwErrorFromResponse(response: Response, batchRequestIdx?: number): Promise<never> {\n let errorCode = response.headers.get('Prisma-Error-Code')\n\n const responseText = await response.text()\n let errorJson: Record<string, unknown>\n let errorMessage = responseText\n\n try {\n errorJson = JSON.parse(responseText)\n } catch {\n errorJson = {}\n }\n\n if (typeof errorJson.code === 'string') {\n errorCode = errorJson.code\n }\n\n if (typeof errorJson.error === 'string') {\n // Query Plan Executor errors\n errorMessage = errorJson.error\n } else if (typeof errorJson.message === 'string') {\n // Accelerate errors\n errorMessage = errorJson.message\n } else if (\n // Certain specific Accelerate errors that mimic the shape of legacy Data Proxy errors\n // for backward compatibility with DataProxyEngine in the Client.\n typeof errorJson.InvalidRequestError === 'object' &&\n errorJson.InvalidRequestError !== null &&\n typeof (errorJson.InvalidRequestError as Record<string, unknown>).reason === 'string'\n ) {\n errorMessage = (errorJson.InvalidRequestError as Record<string, unknown>).reason as string\n }\n\n errorMessage = errorMessage || `HTTP ${response.status}: ${response.statusText}`\n\n const errorMeta =\n typeof errorJson.meta === 'object' && errorJson.meta !== null\n ? (errorJson.meta as Record<string, unknown>)\n : errorJson\n\n throw new PrismaClientKnownRequestError(errorMessage, {\n clientVersion: this.#clientVersion,\n code: errorCode ?? 'P6000',\n batchRequestIdx,\n meta: errorMeta,\n })\n }\n\n #processExtensions(extensions: QueryEngineResultExtensions): void {\n if (extensions.logs) {\n for (const log of extensions.logs) {\n this.#emitLogEvent(log)\n }\n }\n if (extensions.spans) {\n // FIXME: log events should be emitted in the context of the corresponding\n // spans to be consistent with the normal `ClientEngine` behavior. Our\n // current `TracingHelper` interface makes it challenging to do so.\n // We need to either change `dispatchEngineSpans` to be log-aware, or\n // not use `dispatchEngineSpans` here at all and emit the spans directly.\n // The second option is probably better long term so we can get rid of\n // `dispatchEngineSpans` entirely when QC is in GA and the QE is gone.\n this.#tracingHelper.dispatchEngineSpans(extensions.spans)\n }\n }\n\n #emitLogEvent(event: EngineTraceEvent): void {\n switch (event.level) {\n case 'debug':\n case 'trace':\n debug(event)\n break\n\n case 'error':\n case 'warn':\n case 'info': {\n this.#logEmitter.emit(event.level, {\n timestamp: dateFromEngineTimestamp(event.timestamp),\n message: event.attributes.message ?? '',\n target: event.target ?? 'RemoteExecutor',\n })\n break\n }\n\n case 'query': {\n this.#logEmitter.emit('query', {\n query: event.attributes.query ?? '',\n timestamp: dateFromEngineTimestamp(event.timestamp),\n duration: event.attributes.duration_ms ?? 0,\n params: event.attributes.params ?? '',\n target: event.target ?? 'RemoteExecutor',\n })\n\n break\n }\n\n default:\n throw new Error(`Unexpected log level: ${event.level satisfies never}`)\n }\n }\n}\n\n/**\n * HTTP client with support for cookies and machine hint headers.\n *\n * Accelerate uses cookies to route requests inside interactive transactions to\n * the correct instance.\n */\nclass HttpClient {\n readonly #baseUrl: URL\n readonly #cookieJar: Map<string, { name: string; value: string; domain: string; path: string; expires?: Date }>\n #machineHint: string | undefined\n\n constructor(baseUrl: URL) {\n this.#baseUrl = baseUrl\n this.#cookieJar = new Map()\n }\n\n async request({\n method,\n path,\n headers,\n body,\n fetch,\n }: {\n method: string\n path: string\n headers: AccelerateHeaders\n body: unknown\n fetch: AccelerateExtensionFetch\n }): Promise<Response> {\n const requestUrl = new URL(path, this.#baseUrl)\n\n const cookieHeader = this.#getCookieHeader(requestUrl)\n if (cookieHeader) {\n headers['Cookie'] = cookieHeader\n }\n\n if (this.#machineHint) {\n headers['Accelerate-Query-Engine-Jwt'] = this.#machineHint\n }\n\n const response = (await fetch(requestUrl.href, {\n method,\n body: body !== undefined ? JSON.stringify(body) : undefined,\n headers,\n })) as Response\n\n debug(method, requestUrl, response.status, response.statusText)\n\n this.#machineHint = response.headers.get('Accelerate-Query-Engine-Jwt') ?? undefined\n this.#storeCookiesFromResponse(requestUrl, response)\n\n return response\n }\n\n #getCookieHeader(url: URL): string | undefined {\n const validCookies: string[] = []\n const now = new Date()\n\n for (const [key, cookie] of this.#cookieJar) {\n if (cookie.expires && cookie.expires < now) {\n this.#cookieJar.delete(key)\n continue\n }\n\n const domain = cookie.domain ?? url.hostname\n const path = cookie.path ?? '/'\n\n if (url.hostname.endsWith(domain) && url.pathname.startsWith(path)) {\n validCookies.push(serializeCookie(cookie.name, cookie.value))\n }\n }\n\n return validCookies.length > 0 ? validCookies.join('; ') : undefined\n }\n\n #storeCookiesFromResponse(url: URL, response: Response): void {\n // Try to get Set-Cookie headers using the modern API first\n const setCookieHeaders = response.headers.getSetCookie?.() || []\n\n // Fallback to the traditional method if getSetCookie is not available\n if (setCookieHeaders.length === 0) {\n const setCookieHeader = response.headers.get('Set-Cookie')\n if (setCookieHeader) {\n setCookieHeaders.push(setCookieHeader)\n }\n }\n\n for (const cookieString of setCookieHeaders) {\n const cookie = parseSetCookie(cookieString)\n\n const domain = cookie.domain ?? url.hostname\n const path = cookie.path ?? '/'\n const key = `${domain}:${path}:${cookie.name}`\n\n this.#cookieJar.set(key, {\n name: cookie.name,\n value: cookie.value,\n domain,\n path,\n expires: cookie.expires,\n })\n }\n }\n}\n", "function parse(str, options) {\n if (typeof str !== \"string\") {\n throw new TypeError(\"argument str must be a string\");\n }\n const obj = {};\n const opt = options || {};\n const dec = opt.decode || decode;\n let index = 0;\n while (index < str.length) {\n const eqIdx = str.indexOf(\"=\", index);\n if (eqIdx === -1) {\n break;\n }\n let endIdx = str.indexOf(\";\", index);\n if (endIdx === -1) {\n endIdx = str.length;\n } else if (endIdx < eqIdx) {\n index = str.lastIndexOf(\";\", eqIdx - 1) + 1;\n continue;\n }\n const key = str.slice(index, eqIdx).trim();\n if (opt?.filter && !opt?.filter(key)) {\n index = endIdx + 1;\n continue;\n }\n if (void 0 === obj[key]) {\n let val = str.slice(eqIdx + 1, endIdx).trim();\n if (val.codePointAt(0) === 34) {\n val = val.slice(1, -1);\n }\n obj[key] = tryDecode(val, dec);\n }\n index = endIdx + 1;\n }\n return obj;\n}\nfunction decode(str) {\n return str.includes(\"%\") ? decodeURIComponent(str) : str;\n}\nfunction tryDecode(str, decode2) {\n try {\n return decode2(str);\n } catch {\n return str;\n }\n}\n\nconst fieldContentRegExp = /^[\\u0009\\u0020-\\u007E\\u0080-\\u00FF]+$/;\nfunction serialize(name, value, options) {\n const opt = options || {};\n const enc = opt.encode || encodeURIComponent;\n if (typeof enc !== \"function\") {\n throw new TypeError(\"option encode is invalid\");\n }\n if (!fieldContentRegExp.test(name)) {\n throw new TypeError(\"argument name is invalid\");\n }\n const encodedValue = enc(value);\n if (encodedValue && !fieldContentRegExp.test(encodedValue)) {\n throw new TypeError(\"argument val is invalid\");\n }\n let str = name + \"=\" + encodedValue;\n if (void 0 !== opt.maxAge && opt.maxAge !== null) {\n const maxAge = opt.maxAge - 0;\n if (Number.isNaN(maxAge) || !Number.isFinite(maxAge)) {\n throw new TypeError(\"option maxAge is invalid\");\n }\n str += \"; Max-Age=\" + Math.floor(maxAge);\n }\n if (opt.domain) {\n if (!fieldContentRegExp.test(opt.domain)) {\n throw new TypeError(\"option domain is invalid\");\n }\n str += \"; Domain=\" + opt.domain;\n }\n if (opt.path) {\n if (!fieldContentRegExp.test(opt.path)) {\n throw new TypeError(\"option path is invalid\");\n }\n str += \"; Path=\" + opt.path;\n }\n if (opt.expires) {\n if (!isDate(opt.expires) || Number.isNaN(opt.expires.valueOf())) {\n throw new TypeError(\"option expires is invalid\");\n }\n str += \"; Expires=\" + opt.expires.toUTCString();\n }\n if (opt.httpOnly) {\n str += \"; HttpOnly\";\n }\n if (opt.secure) {\n str += \"; Secure\";\n }\n if (opt.priority) {\n const priority = typeof opt.priority === \"string\" ? opt.priority.toLowerCase() : opt.priority;\n switch (priority) {\n case \"low\": {\n str += \"; Priority=Low\";\n break;\n }\n case \"medium\": {\n str += \"; Priority=Medium\";\n break;\n }\n case \"high\": {\n str += \"; Priority=High\";\n break;\n }\n default: {\n throw new TypeError(\"option priority is invalid\");\n }\n }\n }\n if (opt.sameSite) {\n const sameSite = typeof opt.sameSite === \"string\" ? opt.sameSite.toLowerCase() : opt.sameSite;\n switch (sameSite) {\n case true: {\n str += \"; SameSite=Strict\";\n break;\n }\n case \"lax\": {\n str += \"; SameSite=Lax\";\n break;\n }\n case \"strict\": {\n str += \"; SameSite=Strict\";\n break;\n }\n case \"none\": {\n str += \"; SameSite=None\";\n break;\n }\n default: {\n throw new TypeError(\"option sameSite is invalid\");\n }\n }\n }\n if (opt.partitioned) {\n str += \"; Partitioned\";\n }\n return str;\n}\nfunction isDate(val) {\n return Object.prototype.toString.call(val) === \"[object Date]\" || val instanceof Date;\n}\n\nfunction parseSetCookie(setCookieValue, options) {\n const parts = (setCookieValue || \"\").split(\";\").filter((str) => typeof str === \"string\" && !!str.trim());\n const nameValuePairStr = parts.shift() || \"\";\n const parsed = _parseNameValuePair(nameValuePairStr);\n const name = parsed.name;\n let value = parsed.value;\n try {\n value = options?.decode === false ? value : (options?.decode || decodeURIComponent)(value);\n } catch {\n }\n const cookie = {\n name,\n value\n };\n for (const part of parts) {\n const sides = part.split(\"=\");\n const partKey = (sides.shift() || \"\").trimStart().toLowerCase();\n const partValue = sides.join(\"=\");\n switch (partKey) {\n case \"expires\": {\n cookie.expires = new Date(partValue);\n break;\n }\n case \"max-age\": {\n cookie.maxAge = Number.parseInt(partValue, 10);\n break;\n }\n case \"secure\": {\n cookie.secure = true;\n break;\n }\n case \"httponly\": {\n cookie.httpOnly = true;\n break;\n }\n case \"samesite\": {\n cookie.sameSite = partValue;\n break;\n }\n default: {\n cookie[partKey] = partValue;\n }\n }\n }\n return cookie;\n}\nfunction _parseNameValuePair(nameValuePairStr) {\n let name = \"\";\n let value = \"\";\n const nameValueArr = nameValuePairStr.split(\"=\");\n if (nameValueArr.length > 1) {\n name = nameValueArr.shift();\n value = nameValueArr.join(\"=\");\n } else {\n value = nameValuePairStr;\n }\n return { name, value };\n}\n\nfunction splitSetCookieString(cookiesString) {\n if (Array.isArray(cookiesString)) {\n return cookiesString.flatMap((c) => splitSetCookieString(c));\n }\n if (typeof cookiesString !== \"string\") {\n return [];\n }\n const cookiesStrings = [];\n let pos = 0;\n let start;\n let ch;\n let lastComma;\n let nextStart;\n let cookiesSeparatorFound;\n const skipWhitespace = () => {\n while (pos < cookiesString.length && /\\s/.test(cookiesString.charAt(pos))) {\n pos += 1;\n }\n return pos < cookiesString.length;\n };\n const notSpecialChar = () => {\n ch = cookiesString.charAt(pos);\n return ch !== \"=\" && ch !== \";\" && ch !== \",\";\n };\n while (pos < cookiesString.length) {\n start = pos;\n cookiesSeparatorFound = false;\n while (skipWhitespace()) {\n ch = cookiesString.charAt(pos);\n if (ch === \",\") {\n lastComma = pos;\n pos += 1;\n skipWhitespace();\n nextStart = pos;\n while (pos < cookiesString.length && notSpecialChar()) {\n pos += 1;\n }\n if (pos < cookiesString.length && cookiesString.charAt(pos) === \"=\") {\n cookiesSeparatorFound = true;\n pos = nextStart;\n cookiesStrings.push(cookiesString.slice(start, lastComma));\n start = pos;\n } else {\n pos = lastComma + 1;\n }\n } else {\n pos += 1;\n }\n }\n if (!cookiesSeparatorFound || pos >= cookiesString.length) {\n cookiesStrings.push(cookiesString.slice(start));\n }\n }\n return cookiesStrings;\n}\n\nexport { parse, parseSetCookie, serialize, splitSetCookieString };\n", "export interface PrismaClientErrorInfo {\n clientVersion: string\n cause?: Error\n}\n\nexport abstract class PrismaClientError extends Error {\n public abstract name: string\n public abstract code: string\n public clientVersion: string\n public cause?: Error // like https://github.com/es-shims/error-cause\n\n constructor(message: string, info: PrismaClientErrorInfo) {\n super(message)\n\n this.clientVersion = info.clientVersion\n this.cause = info.cause\n }\n\n get [Symbol.toStringTag]() {\n return this.name\n }\n}\n", "import { PrismaClientError, type PrismaClientErrorInfo } from '../../../errors/PrismaClientError'\n\nexport interface AccelerateErrorInfo extends PrismaClientErrorInfo {\n isRetryable?: boolean\n}\n\nexport abstract class AccelerateError extends PrismaClientError {\n isRetryable: boolean\n\n constructor(message: string, info: AccelerateErrorInfo) {\n super(message, info)\n\n this.isRetryable = info.isRetryable ?? true\n }\n}\n", "export function setRetryable<T>(info: T, retryable: boolean) {\n return {\n ...info,\n isRetryable: retryable,\n }\n}\n", "import { setClassName } from '@prisma/internals'\n\nimport type { AccelerateErrorInfo } from './accelerate-error'\nimport { AccelerateError } from './accelerate-error'\nimport { setRetryable } from './utils/set-retryable'\n\nexport interface InvalidDatasourceErrorInfo extends AccelerateErrorInfo {}\nexport class InvalidDatasourceError extends AccelerateError {\n public name = 'InvalidDatasourceError'\n public code = 'P6001'\n\n constructor(message: string, info: InvalidDatasourceErrorInfo) {\n super(message, setRetryable(info, false))\n }\n}\nsetClassName(InvalidDatasourceError, 'InvalidDatasourceError')\n", "import { isPrismaPostgresDev, PRISMA_POSTGRES_PROTOCOL } from '@prisma/internals'\n\nimport { InvalidDatasourceError } from './errors/invalid-datasource-error'\n\nexport interface GetUrlAndApiKeyOptions {\n clientVersion: string\n accelerateUrl: string\n}\n\nexport interface UrlAndApiKey {\n url: HttpUrl\n apiKey: string\n}\n\nexport type HttpUrl = URL & { protocol: 'http' | 'https' }\n\nexport function getUrlAndApiKey(options: GetUrlAndApiKeyOptions): UrlAndApiKey {\n const errorInfo = { clientVersion: options.clientVersion }\n\n let url: URL\n try {\n url = new URL(options.accelerateUrl)\n } catch (err) {\n const message = (err as TypeError).message\n throw new InvalidDatasourceError(\n `Error validating \\`accelerateUrl\\`, the URL cannot be parsed, reason: ${message}`,\n errorInfo,\n )\n }\n\n const { protocol, searchParams } = url\n\n if (protocol !== 'prisma:' && protocol !== PRISMA_POSTGRES_PROTOCOL) {\n throw new InvalidDatasourceError(\n `Error validating \\`accelerateUrl\\`: the URL must start with the protocol \\`prisma://\\` or \\`prisma+postgres://\\``,\n errorInfo,\n )\n }\n\n const apiKey = searchParams.get('api_key')\n if (apiKey === null || apiKey.length < 1) {\n throw new InvalidDatasourceError(\n `Error validating \\`accelerateUrl\\`: the URL must contain a valid API key`,\n errorInfo,\n )\n }\n\n // To simplify things, `prisma dev`, for now, will not support HTTPS.\n // In the future, if HTTPS for `prisma dev` becomes a thing, we'll need this line to be dynamic.\n let httpScheme = isPrismaPostgresDev(url) ? 'http:' : 'https:'\n\n if (process.env.TEST_CLIENT_ENGINE_REMOTE_EXECUTOR && url.searchParams.has('use_http')) {\n httpScheme = 'http:'\n }\n\n // Switching from `prisma:` or `prisma+postgres:` to `http:` or `https:` by\n // assigning to the `protocol` property is not allowed by the WHATWG URL API,\n // it would be silently ignored without throwing an error. We have to manually\n // update the protocol via string replacement.\n const httpUrl = new URL(url.href.replace(protocol, httpScheme)) as HttpUrl\n\n return { apiKey, url: httpUrl }\n}\n", "import type { QueryEngineLogLevel } from '@prisma/client-common'\nimport { enginesVersion } from '@prisma/engines-version'\nimport type { TracingHelper } from '@prisma/instrumentation-contract'\n\nexport type AccelerateHeaders = {\n 'Content-Type': string\n 'Prisma-Engine-Hash': string\n 'Prisma-Engine-Version': string\n 'X-Capture-Telemetry'?: string\n 'X-Transaction-Id'?: string\n Accept: string\n Authorization: string\n traceparent?: string\n}\n\ntype HeaderBuilderOptions = {\n traceparent?: string\n transactionId?: string\n}\n\nexport class HeaderBuilder {\n readonly apiKey: string\n readonly tracingHelper: TracingHelper\n readonly logLevel: QueryEngineLogLevel\n readonly logQueries: boolean | undefined\n readonly engineHash: string\n\n constructor({\n apiKey,\n tracingHelper,\n logLevel,\n logQueries,\n engineHash,\n }: {\n apiKey: string\n tracingHelper: TracingHelper\n logLevel: QueryEngineLogLevel\n logQueries: boolean | undefined\n engineHash: string\n }) {\n this.apiKey = apiKey\n this.tracingHelper = tracingHelper\n this.logLevel = logLevel\n this.logQueries = logQueries\n this.engineHash = engineHash\n }\n\n build({ traceparent, transactionId }: HeaderBuilderOptions = {}): AccelerateHeaders {\n const headers: AccelerateHeaders = {\n Accept: 'application/json',\n Authorization: `Bearer ${this.apiKey}`,\n 'Content-Type': 'application/json',\n 'Prisma-Engine-Hash': this.engineHash,\n 'Prisma-Engine-Version': enginesVersion,\n }\n\n if (this.tracingHelper.isEnabled()) {\n headers.traceparent = traceparent ?? this.tracingHelper.getTraceParent()\n }\n\n if (transactionId) {\n headers['X-Transaction-Id'] = transactionId\n }\n\n const captureTelemetry = this.#buildCaptureSettings()\n\n if (captureTelemetry.length > 0) {\n headers['X-Capture-Telemetry'] = captureTelemetry.join(', ')\n }\n\n return headers\n }\n\n #buildCaptureSettings(): string[] {\n const captureTelemetry: string[] = []\n\n if (this.tracingHelper.isEnabled()) {\n captureTelemetry.push('tracing')\n }\n\n if (this.logLevel) {\n captureTelemetry.push(this.logLevel)\n }\n\n if (this.logQueries) {\n captureTelemetry.push('query')\n }\n\n return captureTelemetry\n }\n}\n", "export type EngineTimestamp = [seconds: number, nanoseconds: number]\n\n/**\n * Converts engine timestamp to JS timestamp, as accepted by `Date` constructor\n */\nexport function convertEngineTimestamp(timestamp: EngineTimestamp): number {\n return timestamp[0] * 1e3 + timestamp[1] / 1e6\n}\n\n/**\n * Parses a `Date` from engine timestamp\n */\nexport function dateFromEngineTimestamp(timestamp: EngineTimestamp): Date {\n return new Date(convertEngineTimestamp(timestamp))\n}\n", "import { QueryCompilerConstructor } from '@prisma/client-common'\nimport { PrismaClientInitializationError } from '@prisma/client-runtime-utils'\n\nimport { QueryCompilerLoader } from './types/QueryCompiler'\n\n// cache loaded wasm instances by provider\nconst loadedWasmInstances: Record<string, Promise<QueryCompilerConstructor>> = {}\n\nexport const wasmQueryCompilerLoader: QueryCompilerLoader = {\n async loadQueryCompiler(config) {\n const { clientVersion, compilerWasm } = config\n\n if (compilerWasm === undefined) {\n throw new PrismaClientInitializationError('WASM query compiler was unexpectedly `undefined`', clientVersion)\n }\n\n let loading: Promise<QueryCompilerConstructor>\n\n // we only create the instance once for efficiency and also because wasm\n // bindgen keeps an internal cache of its instance already, when the wasm\n // compiler is loaded more than once it crashes with `unwrap_throw failed`.\n if (config.activeProvider === undefined || loadedWasmInstances[config.activeProvider] === undefined) {\n loading = (async () => {\n const runtime = await compilerWasm.getRuntime()\n const wasmModule = await compilerWasm.getQueryCompilerWasmModule()\n\n if (wasmModule === undefined || wasmModule === null) {\n throw new PrismaClientInitializationError(\n 'The loaded wasm module was unexpectedly `undefined` or `null` once loaded',\n clientVersion,\n )\n }\n\n // from https://developers.cloudflare.com/workers/runtime-apis/webassembly/rust/#javascript-plumbing-wasm-bindgen\n const options = { [compilerWasm.importName]: runtime }\n const instance = new WebAssembly.Instance(wasmModule, options)\n const wbindgen_start = instance.exports.__wbindgen_start as () => void\n runtime.__wbg_set_wasm(instance.exports)\n wbindgen_start()\n return runtime.QueryCompiler\n })()\n\n // only cache if we have an active provider\n if (config.activeProvider !== undefined) {\n loadedWasmInstances[config.activeProvider] = loading\n }\n } else {\n loading = loadedWasmInstances[config.activeProvider]\n }\n\n return await loading\n },\n}\n", "import { ClientEngine, Engine, EngineConfig } from '../engines'\n\n/**\n * Get the engine instance based on the runtime bundle type and engine configuration.\n */\nexport function getEngineInstance(engineConfig: EngineConfig): Engine {\n return new ClientEngine(engineConfig)\n}\n", "export const rawCommandArgsMapper = (command: object) => ({\n command,\n})\n", "import { Sql } from '@prisma/client-runtime-utils'\nimport { Debug } from '@prisma/debug'\n\nimport { MiddlewareArgsMapper } from '../../getPrismaClient'\nimport { mssqlPreparedStatement } from '../../utils/mssqlPreparedStatement'\nimport { serializeRawParameters } from '../../utils/serializeRawParameters'\nimport { isTypedSql } from '../types/exported'\nimport { RawQueryArgs } from '../types/exported/RawQueryArgs'\n\nconst ALTER_RE = /^(\\s*alter\\s)/i\n\nconst debug = Debug('prisma:client')\n\n// TODO also check/disallow for CREATE, DROP\nexport function checkAlter(activeProvider: string, query: string, values: unknown[], invalidCall: string) {\n if (activeProvider !== 'postgresql' && activeProvider !== 'cockroachdb') {\n return\n }\n if (values.length > 0 && ALTER_RE.exec(query)) {\n // See https://github.com/prisma/prisma-client-js/issues/940 for more info\n throw new Error(`Running ALTER using ${invalidCall} is not supported\nUsing the example below you can still execute your query with Prisma, but please note that it is vulnerable to SQL injection attacks and requires you to take care of input sanitization.\n\nExample:\n await prisma.$executeRawUnsafe(\\`ALTER USER prisma WITH PASSWORD '\\${password}'\\`)\n\nMore Information: https://pris.ly/d/execute-raw\n`)\n }\n}\n\ntype RawQueryArgsMapperInput = {\n clientMethod: string\n activeProvider: string\n}\n\nexport const rawQueryArgsMapper =\n ({ clientMethod, activeProvider }: RawQueryArgsMapperInput) =>\n (args: RawQueryArgs) => {\n // TODO Clean up types\n let queryString = ''\n let parameters: { values: string; __prismaRawParameters__: true } | undefined\n if (isTypedSql(args)) {\n queryString = args.sql\n parameters = {\n values: serializeRawParameters(args.values),\n __prismaRawParameters__: true,\n }\n } else if (Array.isArray(args)) {\n // If this was called as prisma.$executeRaw(<SQL>, [...values]), assume it is a pre-prepared SQL statement, and forward it without any changes\n const [query, ...values] = args\n queryString = query\n parameters = {\n values: serializeRawParameters(values || []),\n __prismaRawParameters__: true,\n }\n } else {\n // If this was called as prisma.$executeRaw`<SQL>` try to generate a SQL prepared statement\n switch (activeProvider) {\n case 'sqlite':\n case 'mysql': {\n queryString = args.sql\n parameters = {\n values: serializeRawParameters(args.values),\n __prismaRawParameters__: true,\n }\n break\n }\n\n case 'cockroachdb':\n case 'postgresql':\n case 'postgres': {\n queryString = args.text\n\n parameters = {\n values: serializeRawParameters(args.values),\n __prismaRawParameters__: true,\n }\n break\n }\n\n case 'sqlserver': {\n queryString = mssqlPreparedStatement(args)\n parameters = {\n values: serializeRawParameters(args.values),\n __prismaRawParameters__: true,\n }\n break\n }\n default: {\n throw new Error(`The ${activeProvider} provider does not support ${clientMethod}`)\n }\n }\n }\n\n if (parameters?.values) {\n debug(`prisma.${clientMethod}(${queryString}, ${parameters.values})`)\n } else {\n debug(`prisma.${clientMethod}(${queryString})`)\n }\n\n return { query: queryString, parameters }\n }\n\ntype MiddlewareRawArgsTemplateString = [string[], ...unknown[]]\ntype MiddlewareRawArgsSql = [Sql]\n\nexport const templateStringMiddlewareArgsMapper: MiddlewareArgsMapper<Sql, MiddlewareRawArgsTemplateString> = {\n requestArgsToMiddlewareArgs(sql) {\n return [sql.strings, ...sql.values]\n },\n\n middlewareArgsToRequestArgs(requestArgs) {\n const [strings, ...values] = requestArgs\n return new Sql(strings, values)\n },\n}\n\nexport const sqlMiddlewareArgsMapper: MiddlewareArgsMapper<Sql, MiddlewareRawArgsSql> = {\n requestArgsToMiddlewareArgs(sql) {\n return [sql]\n },\n\n middlewareArgsToRequestArgs(requestArgs) {\n return requestArgs[0]\n },\n}\n", "import type { Sql } from '@prisma/client-runtime-utils'\n\n// Generate something like: SELECT * FROM User WHERE name = @P1 AND email = @P2 ...\nexport const mssqlPreparedStatement = (sql: Sql) => {\n return sql.strings.reduce((acc, str, idx) => `${acc}@P${idx}${str}`)\n}\n", "import { Decimal } from '@prisma/client-runtime-utils'\n\nimport { isDate } from './date'\n\nexport function serializeRawParameters(parameters: any[]): string {\n try {\n return serializeRawParametersInternal(parameters, 'fast')\n } catch (error) {\n // Got TypeError, try replacing values unsupported by JSON (i.e., BigInts)\n // with strings inside arrays and objects.\n return serializeRawParametersInternal(parameters, 'slow')\n }\n}\n\nfunction serializeRawParametersInternal(parameters: any[], objectSerialization: 'fast' | 'slow'): string {\n return JSON.stringify(parameters.map((parameter) => encodeParameter(parameter, objectSerialization)))\n}\n\nfunction encodeParameter(parameter: any, objectSerialization: 'fast' | 'slow'): unknown {\n if (Array.isArray(parameter)) {\n return parameter.map((item) => encodeParameter(item, objectSerialization))\n }\n if (typeof parameter === 'bigint') {\n return {\n prisma__type: 'bigint',\n prisma__value: parameter.toString(),\n }\n }\n\n if (isDate(parameter)) {\n return {\n prisma__type: 'date',\n prisma__value: parameter.toJSON(),\n }\n }\n\n if (Decimal.isDecimal(parameter)) {\n return {\n prisma__type: 'decimal',\n prisma__value: parameter.toJSON(),\n }\n }\n\n if (Buffer.isBuffer(parameter)) {\n return {\n prisma__type: 'bytes',\n prisma__value: parameter.toString('base64'),\n }\n }\n\n if (isArrayBufferLike(parameter)) {\n return {\n prisma__type: 'bytes',\n prisma__value: Buffer.from(parameter).toString('base64'),\n }\n }\n\n if (ArrayBuffer.isView(parameter)) {\n const { buffer, byteOffset, byteLength } = parameter\n return {\n prisma__type: 'bytes',\n prisma__value: Buffer.from(buffer, byteOffset, byteLength).toString('base64'),\n }\n }\n\n if (typeof parameter === 'object' && objectSerialization === 'slow') {\n return preprocessObject(parameter)\n }\n\n return parameter\n}\n\nfunction isArrayBufferLike(value: any): value is ArrayBufferLike {\n if (value instanceof ArrayBuffer || value instanceof SharedArrayBuffer) {\n return true\n }\n\n if (typeof value === 'object' && value !== null) {\n return value[Symbol.toStringTag] === 'ArrayBuffer' || value[Symbol.toStringTag] === 'SharedArrayBuffer'\n }\n\n return false\n}\n\nfunction preprocessObject(obj: any): unknown {\n if (typeof obj !== 'object' || obj === null) {\n return obj\n }\n\n if (typeof obj.toJSON === 'function') {\n return obj.toJSON()\n }\n\n // TODO: map from blaze would've been convenient here to map arrays and objects uniformly,\n // but importing it in this file causes compilation errors in tsd tests.\n\n if (Array.isArray(obj)) {\n return obj.map(preprocessValueInObject)\n }\n\n const result = {} as any\n\n for (const key of Object.keys(obj as object)) {\n result[key] = preprocessValueInObject(obj[key])\n }\n\n return result\n}\n\nfunction preprocessValueInObject(value: any): unknown {\n if (typeof value === 'bigint') {\n return value.toString()\n }\n\n return preprocessObject(value)\n}\n", "import type { PrismaOperationSpec, PrismaPromise, PrismaPromiseTransaction } from './PrismaPromise'\n\nexport type PrismaPromiseCallback = (transaction?: PrismaPromiseTransaction) => Promise<unknown>\n\n/**\n * Creates a [[PrismaPromise]]. It is Prisma's implementation of `Promise` which\n * is essentially a proxy for `Promise`. All the transaction-compatible client\n * methods return one, this allows for pre-preparing queries without executing\n * them until `.then` is called. It's the foundation of Prisma's query batching.\n * @param callback that will be wrapped within our promise implementation\n * @see [[PrismaPromise]]\n * @returns\n */\nexport type PrismaPromiseFactory = <T extends PrismaOperationSpec<unknown>>(\n callback: PrismaPromiseCallback,\n op?: T,\n) => PrismaPromise<unknown>\n\n/**\n * Creates a factory, that allows creating PrismaPromises, bound to a specific transactions\n * @param transaction\n * @returns\n */\nexport function createPrismaPromiseFactory(transaction?: PrismaPromiseTransaction): PrismaPromiseFactory {\n return function createPrismaPromise<TSpec extends PrismaOperationSpec<unknown>>(\n callback: PrismaPromiseCallback,\n op?: TSpec,\n ): PrismaPromise<unknown, TSpec> {\n let promise: PrismaPromise<unknown> | undefined\n const _callback = (callbackTransaction = transaction): PrismaPromise<unknown> => {\n try {\n // promises cannot be triggered twice after resolving\n if (callbackTransaction === undefined || callbackTransaction?.kind === 'itx') {\n return (promise ??= valueToPromise(callback(callbackTransaction)))\n }\n\n // but for batch tx we can trigger them again & again\n return valueToPromise(callback(callbackTransaction))\n } catch (error) {\n // if the callback throws, then we reject the promise\n // and that is because exceptions are not always async\n return Promise.reject(error) as PrismaPromise<unknown>\n }\n }\n\n return {\n get spec() {\n return op!\n },\n\n then(onFulfilled, onRejected) {\n return _callback().then(onFulfilled, onRejected)\n },\n catch(onRejected) {\n return _callback().catch(onRejected)\n },\n finally(onFinally) {\n return _callback().finally(onFinally)\n },\n\n requestTransaction(batchTransaction) {\n const promise = _callback(batchTransaction)\n\n if (promise.requestTransaction) {\n // we want to have support for nested promises\n return promise.requestTransaction(batchTransaction)\n }\n\n return promise\n },\n [Symbol.toStringTag]: 'PrismaPromise',\n }\n }\n}\n\nfunction valueToPromise<T>(thing: T): PrismaPromise<T> {\n if (typeof thing['then'] === 'function') {\n return thing as PrismaPromise<T>\n }\n\n return Promise.resolve(thing) as PrismaPromise<T>\n}\n", "{\n \"name\": \"@prisma/instrumentation-contract\",\n \"version\": \"7.4.0-integration-parameterization.19\",\n \"description\": \"Shared types and utilities for Prisma instrumentation\",\n \"main\": \"dist/index.js\",\n \"module\": \"dist/index.mjs\",\n \"types\": \"dist/index.d.ts\",\n \"exports\": {\n \".\": {\n \"require\": {\n \"types\": \"./dist/index.d.ts\",\n \"default\": \"./dist/index.js\"\n },\n \"import\": {\n \"types\": \"./dist/index.d.mts\",\n \"default\": \"./dist/index.mjs\"\n }\n }\n },\n \"license\": \"Apache-2.0\",\n \"homepage\": \"https://www.prisma.io\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/prisma/prisma.git\",\n \"directory\": \"packages/instrumentation-contract\"\n },\n \"bugs\": \"https://github.com/prisma/prisma/issues\",\n \"scripts\": {\n \"dev\": \"DEV=true tsx helpers/build.ts\",\n \"build\": \"tsx helpers/build.ts\",\n \"prepublishOnly\": \"pnpm run build\",\n \"test\": \"vitest run\"\n },\n \"files\": [\n \"dist\"\n ],\n \"sideEffects\": false,\n \"devDependencies\": {\n \"@opentelemetry/api\": \"1.9.0\"\n },\n \"peerDependencies\": {\n \"@opentelemetry/api\": \"^1.8\"\n }\n}", "import packageJson from '../package.json'\nimport type { PrismaInstrumentationGlobalValue, TracingHelper } from './types'\n\nconst majorVersion = packageJson.version.split('.')[0]\n\nconst GLOBAL_INSTRUMENTATION_KEY = 'PRISMA_INSTRUMENTATION'\nconst GLOBAL_VERSIONED_INSTRUMENTATION_KEY = `V${majorVersion}_PRISMA_INSTRUMENTATION` as const\n\ntype GlobalThisWithPrismaInstrumentation = typeof globalThis & {\n [GLOBAL_INSTRUMENTATION_KEY]?: PrismaInstrumentationGlobalValue\n} & {\n [K in typeof GLOBAL_VERSIONED_INSTRUMENTATION_KEY]?: PrismaInstrumentationGlobalValue\n}\n\nconst globalThisWithPrismaInstrumentation = globalThis as GlobalThisWithPrismaInstrumentation\n\n/**\n * Returns the TracingHelper from the global instrumentation if available,\n * preferring the versioned global over the fallback global for compatibility.\n */\nexport function getGlobalTracingHelper(): TracingHelper | undefined {\n // Try versioned global first for major version isolation\n const versionedGlobal = globalThisWithPrismaInstrumentation[GLOBAL_VERSIONED_INSTRUMENTATION_KEY]\n\n if (versionedGlobal?.helper) {\n return versionedGlobal.helper\n }\n\n // Fall back to unversioned global for backwards compatibility\n // TODO(v8): Consider removing the fallback in future major versions\n const fallbackGlobal = globalThisWithPrismaInstrumentation[GLOBAL_INSTRUMENTATION_KEY]\n\n return fallbackGlobal?.helper\n}\n\n/**\n * Sets the global tracing helper. This is called by @prisma/instrumentation\n * when instrumentation is enabled.\n */\nexport function setGlobalTracingHelper(helper: TracingHelper): void {\n const globalValue: PrismaInstrumentationGlobalValue = { helper }\n\n // Set both versioned and unversioned globals for compatibility\n // TODO(v8): Consider only writing to the versioned global in future major versions\n globalThisWithPrismaInstrumentation[GLOBAL_VERSIONED_INSTRUMENTATION_KEY] = globalValue\n globalThisWithPrismaInstrumentation[GLOBAL_INSTRUMENTATION_KEY] = globalValue\n}\n\n/**\n * Clears the global tracing helper. This is called by @prisma/instrumentation\n * when instrumentation is disabled.\n */\nexport function clearGlobalTracingHelper(): void {\n delete globalThisWithPrismaInstrumentation[GLOBAL_VERSIONED_INSTRUMENTATION_KEY]\n delete globalThisWithPrismaInstrumentation[GLOBAL_INSTRUMENTATION_KEY]\n}\n", "import type { Context } from '@opentelemetry/api'\nimport {\n EngineSpan,\n ExtendedSpanOptions,\n getGlobalTracingHelper,\n SpanCallback,\n TracingHelper,\n} from '@prisma/instrumentation-contract'\n\nexport const disabledTracingHelper: TracingHelper = {\n isEnabled() {\n return false\n },\n getTraceParent() {\n // https://www.w3.org/TR/trace-context/#examples-of-http-traceparent-headers\n // If traceparent ends with -00 this trace will not be sampled\n // the query engine needs the `10` for the span and trace id otherwise it does not parse this\n return `00-10-10-00`\n },\n\n dispatchEngineSpans() {},\n\n getActiveContext() {\n return undefined\n },\n\n runInChildSpan<R>(options: string | ExtendedSpanOptions, callback: SpanCallback<R>): R {\n return callback()\n },\n}\n\n/**\n * Tracing helper that can dynamically switch between enabled/disabled states\n * Needed because tracing can be disabled and enabled with the calls to\n * PrismaInstrumentation::disable/enable at any point\n */\nclass DynamicTracingHelper implements TracingHelper {\n isEnabled(): boolean {\n return this.getTracingHelper().isEnabled()\n }\n getTraceParent(context: Context) {\n return this.getTracingHelper().getTraceParent(context)\n }\n\n dispatchEngineSpans(spans: EngineSpan[]) {\n return this.getTracingHelper().dispatchEngineSpans(spans)\n }\n\n getActiveContext() {\n return this.getTracingHelper().getActiveContext()\n }\n runInChildSpan<R>(options: string | ExtendedSpanOptions, callback: SpanCallback<R>): R {\n return this.getTracingHelper().runInChildSpan(options, callback)\n }\n\n private getTracingHelper(): TracingHelper {\n return getGlobalTracingHelper() ?? disabledTracingHelper\n }\n}\n\nexport function getTracingHelper(): TracingHelper {\n return new DynamicTracingHelper()\n}\n", "/**\n * Creates an exotic promise that opens after x `await`s.\n * @remarks\n * This is currently used for locking regular transactions.\n * This ensures that all queries are executed at once/batched.\n * Even if middlewares are in use, they'll all execute at once.\n * @param knock the amount of awaits to open the promise\n * @param cb the callback to execute and value to return\n * @returns\n */\nexport function getLockCountPromise<V = void>(knock: number, cb: () => V | void = () => {}) {\n let resolve: (v: V | void) => void\n const lock = new Promise<V | void>((res) => (resolve = res))\n\n return {\n then(onFulfilled) {\n if (--knock === 0) resolve(cb())\n\n return onFulfilled?.(lock as unknown as V | void)\n },\n } as PromiseLike<V | void>\n}\n", "type LogLevel = 'info' | 'query' | 'warn' | 'error'\ntype LogDefinition = {\n level: LogLevel\n emit: 'stdout' | 'event'\n}\n\nexport function getLogLevel(log: LogLevel | Array<LogLevel | LogDefinition>): LogLevel | undefined {\n if (typeof log === 'string') {\n return log\n }\n return log.reduce<LogLevel | undefined>((acc, curr) => {\n const currentLevel = typeof curr === 'string' ? curr : curr.level\n if (currentLevel === 'query') {\n return acc\n }\n if (!acc) {\n return currentLevel\n }\n if (curr === 'info' || acc === 'info') {\n // info has precedence\n return 'info'\n }\n return currentLevel\n }, undefined)\n}\n", "import { Context } from '@opentelemetry/api'\nimport { deserializeJsonResponse } from '@prisma/client-engine-runtime'\nimport { hasBatchIndex } from '@prisma/client-runtime-utils'\nimport { Debug } from '@prisma/debug'\nimport { assertNever } from '@prisma/internals'\nimport stripAnsi from 'strip-ansi'\n\nimport {\n EngineValidationError,\n InteractiveTransactionOptions,\n JsonQuery,\n LogEmitter,\n TransactionOptions,\n} from '../runtime/core/engines'\nimport {\n PrismaClientInitializationError,\n PrismaClientKnownRequestError,\n PrismaClientRustPanicError,\n PrismaClientUnknownRequestError,\n} from '.'\nimport { AccelerateExtensionFetchDecorator } from './core/engines/common/Engine'\nimport { QueryEngineResultData } from './core/engines/common/types/QueryEngine'\nimport { throwValidationException } from './core/errorRendering/throwValidationException'\nimport { createApplyBatchExtensionsFunction } from './core/extensions/applyQueryExtensions'\nimport { MergedExtensionsList } from './core/extensions/MergedExtensionsList'\nimport { getBatchId } from './core/jsonProtocol/getBatchId'\nimport { isWrite } from './core/jsonProtocol/isWrite'\nimport { GlobalOmitOptions } from './core/jsonProtocol/serializeJsonQuery'\nimport { PrismaPromiseInteractiveTransaction, PrismaPromiseTransaction } from './core/request/PrismaPromise'\nimport { Action, JsArgs } from './core/types/exported/JsApi'\nimport { DataLoader } from './DataLoader'\nimport type { Client, Unpacker } from './getPrismaClient'\nimport { CallSite } from './utils/CallSite'\nimport { createErrorMessageWithContext } from './utils/createErrorMessageWithContext'\nimport { deepGet } from './utils/deep-set'\nimport { deserializeRawResult, RawResponse } from './utils/deserializeRawResults'\n\nconst debug = Debug('prisma:client:request_handler')\n\nexport type RequestParams = {\n modelName?: string\n action: Action\n protocolQuery: JsonQuery\n dataPath: string[]\n clientMethod: string\n callsite?: CallSite\n transaction?: PrismaPromiseTransaction\n extensions: MergedExtensionsList\n args?: any\n headers?: Record<string, string>\n unpacker?: Unpacker\n otelParentCtx?: Context\n otelChildCtx?: Context\n globalOmit?: GlobalOmitOptions\n customDataProxyFetch?: AccelerateExtensionFetchDecorator\n}\n\nexport type HandleErrorParams = {\n args: JsArgs\n error: any\n clientMethod: string\n callsite?: CallSite\n transaction?: PrismaPromiseTransaction\n modelName?: string\n globalOmit?: GlobalOmitOptions\n}\n\nexport class RequestHandler {\n client: Client\n dataloader: DataLoader<RequestParams>\n private logEmitter?: LogEmitter\n\n constructor(client: Client, logEmitter?: LogEmitter) {\n this.logEmitter = logEmitter\n this.client = client\n\n this.dataloader = new DataLoader({\n batchLoader: createApplyBatchExtensionsFunction(async ({ requests, customDataProxyFetch }) => {\n const { transaction, otelParentCtx } = requests[0]\n const queries = requests.map((r) => r.protocolQuery)\n const traceparent = this.client._tracingHelper.getTraceParent(otelParentCtx)\n\n // TODO: pass the child information to QE for it to issue links to queries\n // const links = requests.map((r) => trace.getSpanContext(r.otelChildCtx!))\n\n const containsWrite = requests.some((r) => isWrite(r.protocolQuery.action))\n\n const results = await this.client._engine.requestBatch(queries, {\n traceparent,\n transaction: getTransactionOptions(transaction),\n containsWrite,\n customDataProxyFetch,\n })\n\n return results.map((result, i) => {\n if (result instanceof Error) {\n return result\n }\n\n try {\n return this.mapQueryEngineResult(requests[i], result)\n } catch (error) {\n return error\n }\n })\n }),\n\n singleLoader: async (request) => {\n const interactiveTransaction =\n request.transaction?.kind === 'itx' ? getItxTransactionOptions(request.transaction) : undefined\n\n const response = await this.client._engine.request(request.protocolQuery, {\n traceparent: this.client._tracingHelper.getTraceParent(),\n interactiveTransaction,\n isWrite: isWrite(request.protocolQuery.action),\n customDataProxyFetch: request.customDataProxyFetch,\n })\n return this.mapQueryEngineResult(request, response)\n },\n\n batchBy: (request) => {\n if (request.transaction?.id) {\n return `transaction-${request.transaction.id}`\n }\n\n return getBatchId(request.protocolQuery)\n },\n\n batchOrder(requestA, requestB) {\n if (requestA.transaction?.kind === 'batch' && requestB.transaction?.kind === 'batch') {\n return requestA.transaction.index - requestB.transaction.index\n }\n return 0\n },\n })\n }\n\n async request(params: RequestParams) {\n try {\n return await this.dataloader.request(params)\n } catch (error) {\n const { clientMethod, callsite, transaction, args, modelName } = params\n this.handleAndLogRequestError({\n error,\n clientMethod,\n callsite,\n transaction,\n args,\n modelName,\n globalOmit: params.globalOmit,\n })\n }\n }\n\n mapQueryEngineResult({ dataPath, unpacker }: RequestParams, response: QueryEngineResultData<any>) {\n const data = response?.data\n\n /**\n * Unpack\n */\n const result = this.unpack(data, dataPath, unpacker)\n if (process.env.PRISMA_CLIENT_GET_TIME) {\n return { data: result }\n }\n return result\n }\n\n /**\n * Handles the error and logs it, logging the error is done synchronously waiting for the event\n * handlers to finish.\n */\n handleAndLogRequestError(params: HandleErrorParams): never {\n try {\n this.handleRequestError(params)\n } catch (err) {\n if (this.logEmitter) {\n this.logEmitter.emit('error', { message: err.message, target: params.clientMethod, timestamp: new Date() })\n }\n throw err\n }\n }\n\n handleRequestError({\n error,\n clientMethod,\n callsite,\n transaction,\n args,\n modelName,\n globalOmit,\n }: HandleErrorParams): never {\n debug(error)\n\n if (isMismatchingBatchIndex(error, transaction)) {\n // if this is batch error and current request was not it's cause, we don't add\n // context information to the error: this wasn't a request that caused batch to fail\n throw error\n }\n\n if (error instanceof PrismaClientKnownRequestError && isValidationError(error)) {\n const validationError = convertValidationError(error.meta as EngineValidationError)\n throwValidationException({\n args,\n errors: [validationError],\n callsite,\n errorFormat: this.client._errorFormat,\n originalMethod: clientMethod,\n clientVersion: this.client._clientVersion,\n globalOmit,\n })\n }\n\n let message = error.message\n if (callsite) {\n message = createErrorMessageWithContext({\n callsite,\n originalMethod: clientMethod,\n isPanic: error.isPanic,\n showColors: this.client._errorFormat === 'pretty',\n message,\n })\n }\n\n message = this.sanitizeMessage(message)\n // TODO: Do request with callsite instead, so we don't need to rethrow\n if (error.code) {\n const meta = modelName ? { modelName, ...error.meta } : error.meta\n throw new PrismaClientKnownRequestError(message, {\n code: error.code,\n clientVersion: this.client._clientVersion,\n meta,\n batchRequestIdx: error.batchRequestIdx,\n })\n } else if (error.isPanic) {\n throw new PrismaClientRustPanicError(message, this.client._clientVersion)\n } else if (error instanceof PrismaClientUnknownRequestError) {\n throw new PrismaClientUnknownRequestError(message, {\n clientVersion: this.client._clientVersion,\n batchRequestIdx: error.batchRequestIdx,\n })\n } else if (error instanceof PrismaClientInitializationError) {\n throw new PrismaClientInitializationError(message, this.client._clientVersion)\n } else if (error instanceof PrismaClientRustPanicError) {\n throw new PrismaClientRustPanicError(message, this.client._clientVersion)\n }\n\n error.clientVersion = this.client._clientVersion\n\n throw error\n }\n\n sanitizeMessage(message) {\n if (this.client._errorFormat && this.client._errorFormat !== 'pretty') {\n return stripAnsi(message)\n }\n return message\n }\n\n unpack(data: unknown, dataPath: string[], unpacker?: Unpacker) {\n if (!data) {\n return data\n }\n if (data['data']) {\n data = data['data']\n }\n\n if (!data) {\n return data\n }\n const operation = Object.keys(data)[0]\n const response = Object.values(data)[0]\n const pathForGet = dataPath.filter((key) => key !== 'select' && key !== 'include')\n const extractedResponse = deepGet(response, pathForGet)\n const deserializedResponse =\n operation === 'queryRaw'\n ? deserializeRawResult(extractedResponse as RawResponse)\n : (deserializeJsonResponse(extractedResponse) as unknown)\n\n return unpacker ? unpacker(deserializedResponse) : deserializedResponse\n }\n\n get [Symbol.toStringTag]() {\n return 'RequestHandler'\n }\n}\n\nfunction getTransactionOptions<PayloadType>(\n transaction?: PrismaPromiseTransaction<PayloadType>,\n): TransactionOptions<PayloadType> | undefined {\n if (!transaction) {\n return undefined\n }\n\n if (transaction.kind === 'batch') {\n return {\n kind: 'batch',\n options: {\n isolationLevel: transaction.isolationLevel,\n },\n }\n }\n\n if (transaction.kind === 'itx') {\n return {\n kind: 'itx',\n options: getItxTransactionOptions(transaction),\n }\n }\n\n assertNever(transaction, 'Unknown transaction kind')\n}\n\nfunction getItxTransactionOptions<PayloadType>(\n transaction: PrismaPromiseInteractiveTransaction<PayloadType>,\n): InteractiveTransactionOptions<PayloadType> {\n return {\n id: transaction.id,\n payload: transaction.payload,\n }\n}\n\nfunction isMismatchingBatchIndex(error: any, transaction: PrismaPromiseTransaction | undefined) {\n return hasBatchIndex(error) && transaction?.kind === 'batch' && error.batchRequestIdx !== transaction.index\n}\n\nfunction isValidationError(error: PrismaClientKnownRequestError) {\n return (\n error.code === 'P2009' || // validation error\n error.code === 'P2012' // required argument missing\n )\n}\n\n/**\n * Engine validation errors include extra segment for selectionPath - root query field.\n * This function removes it (since it does not exist on js arguments). In case of `Union`\n * error type, removes heading element from selectionPath of nested errors as well.\n * @param error\n * @returns\n */\nfunction convertValidationError(error: EngineValidationError): EngineValidationError {\n if (error.kind === 'Union') {\n return {\n kind: 'Union',\n errors: error.errors.map(convertValidationError),\n }\n }\n\n if (Array.isArray(error['selectionPath'])) {\n const [, ...selectionPath] = error['selectionPath']\n\n return {\n ...error,\n selectionPath,\n } as EngineValidationError\n }\n\n return error\n}\n", "import { JsonQuery } from '../engines'\n\nexport function getBatchId(query: JsonQuery): string | undefined {\n if (query.action !== 'findUnique' && query.action !== 'findUniqueOrThrow') {\n return undefined\n }\n const parts: string[] = []\n if (query.modelName) {\n parts.push(query.modelName)\n }\n\n if (query.query.arguments) {\n parts.push(buildKeysString(query.query.arguments))\n }\n parts.push(buildKeysString(query.query.selection))\n\n return parts.join('')\n}\n\nfunction buildKeysString(obj: object): string {\n const keysArray = Object.keys(obj)\n .sort()\n .map((key) => {\n const value = obj[key]\n if (typeof value === 'object' && value !== null) {\n return `(${key} ${buildKeysString(value)})`\n }\n return key\n })\n\n return `(${keysArray.join(' ')})`\n}\n", "import { JsonQueryAction } from '../engines'\n\nconst writeMap: Record<JsonQueryAction, boolean> = {\n aggregate: false,\n aggregateRaw: false,\n createMany: true,\n createManyAndReturn: true,\n createOne: true,\n deleteMany: true,\n deleteOne: true,\n executeRaw: true,\n findFirst: false,\n findFirstOrThrow: false,\n findMany: false,\n findRaw: false,\n findUnique: false,\n findUniqueOrThrow: false,\n groupBy: false,\n queryRaw: false,\n runCommandRaw: true,\n updateMany: true,\n updateManyAndReturn: true,\n updateOne: true,\n upsertOne: true,\n}\n\nexport function isWrite(action: JsonQueryAction): boolean {\n return writeMap[action]\n}\n", "interface Job {\n resolve: (data: any) => void\n reject: (data: any) => void\n request: any\n}\n\nexport type DataLoaderOptions<T> = {\n singleLoader: (request: T) => Promise<any>\n batchLoader: (request: T[]) => Promise<any[]>\n batchBy: (request: T) => string | undefined\n // Specifies the order in which requests in a batch would\n // be sorted. See Array.prototype.sort callback\n batchOrder: (requestA: T, requestB: T) => number\n}\n\nexport class DataLoader<T = unknown> {\n batches: { [key: string]: Job[] }\n private tickActive = false\n constructor(private options: DataLoaderOptions<T>) {\n this.batches = {}\n }\n\n request(request: T): Promise<any> {\n const hash = this.options.batchBy(request)\n if (!hash) {\n return this.options.singleLoader(request)\n }\n if (!this.batches[hash]) {\n this.batches[hash] = []\n\n // make sure, that we only tick once at a time\n if (!this.tickActive) {\n this.tickActive = true\n process.nextTick(() => {\n this.dispatchBatches()\n this.tickActive = false\n })\n }\n }\n\n return new Promise((resolve, reject) => {\n this.batches[hash].push({\n request,\n resolve,\n reject,\n })\n })\n }\n\n private dispatchBatches() {\n for (const key in this.batches) {\n const batch = this.batches[key]\n delete this.batches[key]\n\n // only batch if necessary\n // this might occur, if there's e.g. only 1 findUnique in the batch\n if (batch.length === 1) {\n this.options\n .singleLoader(batch[0].request)\n .then((result) => {\n if (result instanceof Error) {\n batch[0].reject(result)\n } else {\n batch[0].resolve(result)\n }\n })\n .catch((e) => {\n batch[0].reject(e)\n })\n } else {\n batch.sort((a, b) => this.options.batchOrder(a.request, b.request))\n this.options\n .batchLoader(batch.map((j) => j.request))\n .then((results) => {\n if (results instanceof Error) {\n for (let i = 0; i < batch.length; i++) {\n batch[i].reject(results)\n }\n } else {\n for (let i = 0; i < batch.length; i++) {\n const value = results[i]\n if (value instanceof Error) {\n batch[i].reject(value)\n } else {\n batch[i].resolve(value)\n }\n }\n }\n })\n .catch((e) => {\n for (let i = 0; i < batch.length; i++) {\n batch[i].reject(e)\n }\n })\n }\n }\n }\n\n get [Symbol.toStringTag]() {\n return 'DataLoader'\n }\n}\n", "import { Decimal } from '@prisma/client-runtime-utils'\nimport type { QueryIntrospectionBuiltinType } from '@prisma/generator'\n\nexport type RawResponse = {\n columns: string[]\n types: QueryIntrospectionBuiltinType[]\n rows: unknown[][]\n}\n\nfunction deserializeValue(type: QueryIntrospectionBuiltinType, value: unknown): unknown {\n if (value === null) {\n return value\n }\n\n switch (type) {\n case 'bigint':\n return BigInt(value as string)\n\n case 'bytes': {\n const { buffer, byteOffset, byteLength } = Buffer.from(value as string, 'base64')\n return new Uint8Array(buffer, byteOffset, byteLength)\n }\n\n case 'decimal':\n return new Decimal(value as string)\n\n case 'datetime':\n case 'date':\n return new Date(value as string)\n\n case 'time':\n return new Date(`1970-01-01T${value}Z`)\n\n case 'bigint-array':\n return (value as unknown[]).map((v: unknown) => deserializeValue('bigint', v))\n case 'bytes-array':\n return (value as unknown[]).map((v: unknown) => deserializeValue('bytes', v))\n case 'decimal-array':\n return (value as unknown[]).map((v: unknown) => deserializeValue('decimal', v))\n case 'datetime-array':\n return (value as unknown[]).map((v: unknown) => deserializeValue('datetime', v))\n case 'date-array':\n return (value as unknown[]).map((v: unknown) => deserializeValue('date', v))\n case 'time-array':\n return (value as unknown[]).map((v: unknown) => deserializeValue('time', v))\n\n default:\n return value\n }\n}\n\ntype DeserializedResponse = Array<Record<string, unknown>>\n\nexport function deserializeRawResult(response: RawResponse): DeserializedResponse {\n const deserializedResponse: DeserializedResponse = []\n // Performance optimization. See https://github.com/brianc/node-postgres/issues/3042\n const prebuiltEmptyObject = createPrebuiltEmptyResultObject(response)\n\n for (let i = 0; i < response.rows.length; i++) {\n const row = response.rows[i]\n const mappedRow = { ...prebuiltEmptyObject } as Record<string, unknown>\n\n for (let j = 0; j < row.length; j++) {\n mappedRow[response.columns[j]] = deserializeValue(response.types[j], row[j])\n }\n\n deserializedResponse.push(mappedRow)\n }\n\n return deserializedResponse\n}\n\nfunction createPrebuiltEmptyResultObject(response: RawResponse): Record<string, null> {\n const row = {}\n\n for (let i = 0; i < response.columns.length; i++) {\n row[response.columns[i]] = null\n }\n\n return row\n}\n", "import { version } from '../../../package.json'\n\nexport const clientVersion = version as string\n", "import { GetPrismaClientConfig, RuntimeDataModel, RuntimeModel, uncapitalize } from '@prisma/client-common'\nimport leven from 'js-levenshtein'\n\nimport { buildArgumentsRenderingTree, renderArgsTree } from '../core/errorRendering/ArgumentsRenderingTree'\nimport { PrismaClientConstructorValidationError } from '../core/errors/PrismaClientConstructorValidationError'\nimport type { ErrorFormat, LogLevel, PrismaClientOptions } from '../getPrismaClient'\n\nconst knownProperties = [\n 'errorFormat',\n 'adapter',\n 'accelerateUrl',\n 'log',\n 'transactionOptions',\n 'omit',\n 'comments',\n '__internal',\n]\nconst errorFormats: ErrorFormat[] = ['pretty', 'colorless', 'minimal']\nconst logLevels: LogLevel[] = ['info', 'query', 'warn', 'error']\n\ntype OmitValidationError =\n | { kind: 'UnknownModel'; modelKey: string }\n | { kind: 'UnknownField'; modelKey: string; fieldName: string }\n | { kind: 'RelationInOmit'; modelKey: string; fieldName: string }\n | { kind: 'InvalidFieldValue'; modelKey: string; fieldName: string }\n\n/**\n * Subset of `GetPrismaClientConfig` which is used during validation.\n * Feel free to allow more properties when necessary but don't forget to add\n * them in the mock config in `validatePrismaClientOptions.test.ts`.\n */\nexport type ClientConfig = Pick<GetPrismaClientConfig, 'previewFeatures' | 'runtimeDataModel'>\n\nconst validators: {\n [K in keyof PrismaClientOptions]-?: (option: PrismaClientOptions[K], config: ClientConfig) => void\n} = {\n adapter: () => {},\n accelerateUrl: (accelerateUrl) => {\n if (accelerateUrl === undefined) {\n return\n }\n\n if (typeof accelerateUrl !== 'string') {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${JSON.stringify(accelerateUrl)} for \"accelerateUrl\" provided to PrismaClient constructor.`,\n )\n }\n\n if (accelerateUrl.trim().length === 0) {\n throw new PrismaClientConstructorValidationError(\n `\"accelerateUrl\" provided to PrismaClient constructor must be a non-empty string.`,\n )\n }\n },\n errorFormat: (options) => {\n if (!options) {\n return\n }\n if (typeof options !== 'string') {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${JSON.stringify(options)} for \"errorFormat\" provided to PrismaClient constructor.`,\n )\n }\n if (!errorFormats.includes(options as ErrorFormat)) {\n const didYouMean = getDidYouMean(options, errorFormats)\n throw new PrismaClientConstructorValidationError(\n `Invalid errorFormat ${options} provided to PrismaClient constructor.${didYouMean}`,\n )\n }\n },\n log: (options) => {\n if (!options) {\n return\n }\n if (!Array.isArray(options)) {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${JSON.stringify(options)} for \"log\" provided to PrismaClient constructor.`,\n )\n }\n\n function validateLogLevel(level: any) {\n if (typeof level === 'string') {\n if (!logLevels.includes(level as LogLevel)) {\n const didYouMean = getDidYouMean(level, logLevels)\n throw new PrismaClientConstructorValidationError(\n `Invalid log level \"${level}\" provided to PrismaClient constructor.${didYouMean}`,\n )\n }\n }\n }\n\n for (const option of options) {\n validateLogLevel(option)\n\n const logValidators = {\n level: validateLogLevel,\n emit: (value) => {\n const emits = ['stdout', 'event']\n if (!emits.includes(value)) {\n const didYouMean = getDidYouMean(value, emits)\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${JSON.stringify(\n value,\n )} for \"emit\" in logLevel provided to PrismaClient constructor.${didYouMean}`,\n )\n }\n },\n }\n\n if (option && typeof option === 'object') {\n for (const [key, value] of Object.entries(option)) {\n if (logValidators[key]) {\n logValidators[key](value)\n } else {\n throw new PrismaClientConstructorValidationError(\n `Invalid property ${key} for \"log\" provided to PrismaClient constructor`,\n )\n }\n }\n }\n }\n },\n transactionOptions: (options: any) => {\n if (!options) {\n return\n }\n\n const maxWait = options.maxWait\n if (maxWait != null && maxWait <= 0) {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${maxWait} for maxWait in \"transactionOptions\" provided to PrismaClient constructor. maxWait needs to be greater than 0`,\n )\n }\n\n const timeout = options.timeout\n if (timeout != null && timeout <= 0) {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${timeout} for timeout in \"transactionOptions\" provided to PrismaClient constructor. timeout needs to be greater than 0`,\n )\n }\n },\n omit: (options: unknown, config) => {\n if (typeof options !== 'object') {\n throw new PrismaClientConstructorValidationError(`\"omit\" option is expected to be an object.`)\n }\n if (options === null) {\n throw new PrismaClientConstructorValidationError(`\"omit\" option can not be \\`null\\``)\n }\n\n const validationErrors: OmitValidationError[] = []\n for (const [modelKey, modelConfig] of Object.entries(options)) {\n const modelOrType = getModelOrTypeByKey(modelKey, config.runtimeDataModel)\n if (!modelOrType) {\n validationErrors.push({ kind: 'UnknownModel', modelKey: modelKey })\n continue\n }\n for (const [fieldName, value] of Object.entries(modelConfig)) {\n const field = modelOrType.fields.find((field) => field.name === fieldName)\n if (!field) {\n validationErrors.push({ kind: 'UnknownField', modelKey, fieldName })\n continue\n }\n if (field.relationName) {\n validationErrors.push({ kind: 'RelationInOmit', modelKey, fieldName })\n continue\n }\n if (typeof value !== 'boolean') {\n validationErrors.push({ kind: 'InvalidFieldValue', modelKey, fieldName })\n }\n }\n }\n if (validationErrors.length > 0) {\n throw new PrismaClientConstructorValidationError(\n renderOmitValidationErrors(options as Record<string, unknown>, validationErrors),\n )\n }\n },\n comments: (options) => {\n if (options === undefined) {\n return\n }\n if (!Array.isArray(options)) {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${JSON.stringify(options)} for \"comments\" provided to PrismaClient constructor. Expected an array of SQL commenter plugins.`,\n )\n }\n for (let i = 0; i < options.length; i++) {\n if (typeof options[i] !== 'function') {\n throw new PrismaClientConstructorValidationError(\n `Invalid value at index ${i} for \"comments\" provided to PrismaClient constructor. Each plugin must be a function.`,\n )\n }\n }\n },\n __internal: (value) => {\n if (!value) {\n return\n }\n const knownKeys = ['debug', 'engine', 'configOverride']\n if (typeof value !== 'object') {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${JSON.stringify(value)} for \"__internal\" to PrismaClient constructor`,\n )\n }\n for (const [key] of Object.entries(value)) {\n if (!knownKeys.includes(key)) {\n const didYouMean = getDidYouMean(key, knownKeys)\n throw new PrismaClientConstructorValidationError(\n `Invalid property ${JSON.stringify(key)} for \"__internal\" provided to PrismaClient constructor.${didYouMean}`,\n )\n }\n }\n // TODO: Add more validation here\n // but as this is an internal, non user-facing api, it's not urgent\n },\n}\n\nfunction validateDependentOptions(options: PrismaClientOptions) {\n const adapterProvided = options.adapter !== undefined\n const accelerateUrlProvided = options.accelerateUrl !== undefined\n\n if (adapterProvided && accelerateUrlProvided) {\n throw new PrismaClientConstructorValidationError(\n `The \"adapter\" and \"accelerateUrl\" options are mutually exclusive. Please provide only one of them.`,\n )\n }\n\n if (!adapterProvided && !accelerateUrlProvided) {\n throw new PrismaClientConstructorValidationError(\n `Using engine type \"client\" requires either \"adapter\" or \"accelerateUrl\" to be provided to PrismaClient constructor.`,\n )\n }\n}\n\nexport function validatePrismaClientOptions(options: PrismaClientOptions, config: ClientConfig) {\n for (const [key, value] of Object.entries(options)) {\n if (!knownProperties.includes(key)) {\n const didYouMean = getDidYouMean(key, knownProperties)\n throw new PrismaClientConstructorValidationError(\n `Unknown property ${key} provided to PrismaClient constructor.${didYouMean}`,\n )\n }\n validators[key](value, config)\n }\n\n validateDependentOptions(options)\n}\n\nfunction getDidYouMean(str: string, options: string[]): string {\n if (options.length === 0) {\n return ''\n }\n\n if (typeof str !== 'string') {\n return ''\n }\n\n const alternative = getAlternative(str, options)\n if (!alternative) {\n return ''\n }\n\n return ` Did you mean \"${alternative}\"?`\n}\n\nfunction getAlternative(str: string, options: string[]): null | string {\n if (options.length === 0) {\n return null\n }\n\n const optionsWithDistances = options.map((value) => ({\n value,\n distance: leven(str, value),\n }))\n\n optionsWithDistances.sort((a, b) => {\n return a.distance < b.distance ? -1 : 1\n })\n\n const bestAlternative = optionsWithDistances[0]\n if (bestAlternative.distance < 3) {\n return bestAlternative.value\n }\n\n return null\n}\n\nfunction getModelOrTypeByKey(modelKey: string, runtimeDataModel: RuntimeDataModel): RuntimeModel | undefined {\n return findByKey(runtimeDataModel.models, modelKey) ?? findByKey(runtimeDataModel.types, modelKey)\n}\n\nfunction findByKey<T>(map: Record<string, T>, key: string): T | undefined {\n const foundKey = Object.keys(map).find((mapKey) => uncapitalize(mapKey) === key)\n if (foundKey) {\n return map[foundKey]\n }\n return undefined\n}\n\nfunction renderOmitValidationErrors(\n omitConfig: Record<PropertyKey, unknown>,\n validationErrors: OmitValidationError[],\n): string {\n const argsTree = buildArgumentsRenderingTree(omitConfig)\n for (const error of validationErrors) {\n switch (error.kind) {\n case 'UnknownModel':\n argsTree.arguments.getField(error.modelKey)?.markAsError()\n argsTree.addErrorMessage(() => `Unknown model name: ${error.modelKey}.`)\n break\n case 'UnknownField':\n argsTree.arguments.getDeepField([error.modelKey, error.fieldName])?.markAsError()\n argsTree.addErrorMessage(() => `Model \"${error.modelKey}\" does not have a field named \"${error.fieldName}\".`)\n break\n case 'RelationInOmit':\n argsTree.arguments.getDeepField([error.modelKey, error.fieldName])?.markAsError()\n argsTree.addErrorMessage(() => `Relations are already excluded by default and can not be specified in \"omit\".`)\n break\n case 'InvalidFieldValue':\n argsTree.arguments.getDeepFieldValue([error.modelKey, error.fieldName])?.markAsError()\n argsTree.addErrorMessage(() => `Omit field option value must be a boolean.`)\n break\n }\n }\n const { message, args } = renderArgsTree(argsTree, 'colorless')\n return `Error validating \"omit\" option:\\n\\n${args}\\n\\n${message}`\n}\n", "import { setClassName } from '@prisma/internals'\n\nexport class PrismaClientConstructorValidationError extends Error {\n constructor(message: string) {\n super(message + `\\nRead more at https://pris.ly/d/client-constructor`)\n this.name = 'PrismaClientConstructorValidationError'\n }\n get [Symbol.toStringTag]() {\n return 'PrismaClientConstructorValidationError'\n }\n}\nsetClassName(PrismaClientConstructorValidationError, 'PrismaClientConstructorValidationError')\n", "import { hasBatchIndex } from '@prisma/client-runtime-utils'\n\n/**\n * Waits for result of batch $transaction and picks the best possible error to report if any\n * of the request fails. Best error is determined as follows:\n *\n * - if engine have reported an error without batch request index, then the batch is immediately rejected\n * with this error without waiting for other promises\n * - if engine have reported and index of failed request in the batch and that index matches the position of the\n * particular request in the batch, batch is rejected with that error\n * - if batch request index is reported and it does not match current request position, wait for other requests. If no indices\n * match request positions, reject with the earliest error in the batch\n *\n * @param promises\n * @returns\n */\nexport function waitForBatch<T extends PromiseLike<unknown>[]>(\n promises: T,\n): Promise<{ [K in keyof T]: Awaited<T[K]> }> {\n if (promises.length === 0) {\n return Promise.resolve([] as { [K in keyof T]: Awaited<T[K]> })\n }\n return new Promise((resolve, reject) => {\n const successfulResults = new Array(promises.length) as { [K in keyof T]: Awaited<T[K]> }\n let bestError: unknown = null\n let done = false\n let settledPromisesCount = 0\n\n const settleOnePromise = () => {\n if (done) {\n return\n }\n settledPromisesCount++\n if (settledPromisesCount === promises.length) {\n done = true\n if (bestError) {\n reject(bestError)\n } else {\n resolve(successfulResults)\n }\n }\n }\n\n const immediatelyReject = (error: unknown) => {\n if (!done) {\n done = true\n reject(error)\n }\n }\n\n for (let i = 0; i < promises.length; i++) {\n promises[i].then(\n (result) => {\n successfulResults[i] = result\n settleOnePromise()\n },\n (error) => {\n if (!hasBatchIndex(error)) {\n immediatelyReject(error)\n return\n }\n\n if (error.batchRequestIdx === i) {\n immediatelyReject(error)\n } else {\n if (!bestError) {\n bestError = error\n }\n settleOnePromise()\n }\n },\n )\n }\n })\n}\n", "/**\n * List of properties that won't throw exception on access and return undefined instead\n */\nconst allowList = new Set([\n 'toJSON', // used by JSON.stringify\n '$$typeof', // used by old React tooling\n 'asymmetricMatch', // used by Jest\n Symbol.iterator, // used by various JS constructs/methods\n Symbol.toStringTag, // Used by .toString()\n Symbol.isConcatSpreadable, // Used by Array#concat,\n Symbol.toPrimitive, // Used when getting converted to primitive values\n])\n/**\n * Generates more strict variant of an enum which, unlike regular enum,\n * throws on non-existing property access. This can be useful in following situations:\n * - we have an API, that accepts both `undefined` and `SomeEnumType` as an input\n * - enum values are generated dynamically from DMMF.\n *\n * In that case, if using normal enums and no compile-time typechecking, using non-existing property\n * will result in `undefined` value being used, which will be accepted. Using strict enum\n * in this case will help to have a runtime exception, telling you that you are probably doing something wrong.\n *\n * Note: if you need to check for existence of a value in the enum you can still use either\n * `in` operator or `hasOwnProperty` function.\n *\n * @param definition\n * @returns\n */\nexport function makeStrictEnum<T extends Record<PropertyKey, string | number>>(definition: T): T {\n return new Proxy(definition, {\n get(target, property) {\n if (property in target) {\n return target[property]\n }\n if (allowList.has(property)) {\n return undefined\n }\n throw new TypeError(`Invalid enum value: ${String(property)}`)\n },\n })\n}\n", "// https://runtime-keys.proposal.wintercg.org/\nexport type RuntimeName = 'workerd' | 'deno' | 'netlify' | 'node' | 'bun' | 'edge-light' | '' /* unknown */\n\n/**\n * Indicates if running in Node.js or a Node.js compatible runtime.\n *\n * **Note:** When running code in Bun and Deno with Node.js compatibility mode, `isNode` flag will be also `true`, indicating running in a Node.js compatible runtime.\n */\nconst isNode = () => globalThis.process?.release?.name === 'node'\n\n/**\n * Indicates if running in Bun runtime.\n */\nconst isBun = () => !!globalThis.Bun || !!globalThis.process?.versions?.bun\n\n/**\n * Indicates if running in Deno runtime.\n */\nconst isDeno = () => !!globalThis.Deno\n\n/**\n * Indicates if running in Netlify runtime.\n */\nconst isNetlify = () => typeof globalThis.Netlify === 'object'\n\n/**\n * Indicates if running in EdgeLight (Vercel Edge) runtime.\n */\nconst isEdgeLight = () => typeof globalThis.EdgeRuntime === 'object'\n\n/**\n * Indicates if running in Cloudflare Workers runtime.\n * See: https://developers.cloudflare.com/workers/runtime-apis/web-standards/#navigatoruseragent\n */\nconst isWorkerd = () => globalThis.navigator?.userAgent === 'Cloudflare-Workers'\n\nfunction detectRuntime(): RuntimeName {\n // Note: we're currently not taking 'fastly' into account. Why?\n const runtimeChecks = [\n [isNetlify, 'netlify'],\n [isEdgeLight, 'edge-light'],\n [isWorkerd, 'workerd'],\n [isDeno, 'deno'],\n [isBun, 'bun'],\n [isNode, 'node'],\n ] as const\n\n const detectedRuntime =\n runtimeChecks\n // TODO: Transforming destructuring to the configured target environment ('chrome58', 'edge16', 'firefox57', 'safari11') is not supported yet,\n // so we can't write the following code yet:\n // ```\n // .flatMap(([isCurrentRuntime, runtime]) => isCurrentRuntime() ? [runtime] : [])\n // ```\n .flatMap((check) => (check[0]() ? [check[1]] : []))\n .at(0) ?? ''\n\n return detectedRuntime\n}\n\nconst runtimesPrettyNames = {\n node: 'Node.js',\n workerd: 'Cloudflare Workers',\n deno: 'Deno and Deno Deploy',\n netlify: 'Netlify Edge Functions',\n 'edge-light':\n 'Edge Runtime (Vercel Edge Functions, Vercel Edge Middleware, Next.js (Pages Router) Edge API Routes, Next.js (App Router) Edge Route Handlers or Next.js Middleware)',\n} as const\n\ntype GetRuntimeOutput = {\n id: RuntimeName\n prettyName: string\n isEdge: boolean\n}\n\nexport function getRuntime(): GetRuntimeOutput {\n const runtimeId = detectRuntime()\n\n return {\n id: runtimeId,\n // Fallback to the runtimeId if the runtime is not in the list\n prettyName: runtimesPrettyNames[runtimeId] || runtimeId,\n isEdge: ['workerd', 'deno', 'netlify', 'edge-light'].includes(runtimeId),\n }\n}\n", "import * as Extensions from './core/extensions'\nimport * as Public from './core/public'\nimport * as Types from './core/types'\n\nexport { type Types }\nexport { Extensions }\nexport { Public }\n\nexport { type JsonBatchQuery, type JsonQuery } from './core/engines'\nexport { serializeJsonQuery } from './core/jsonProtocol/serializeJsonQuery'\nexport { createParam } from './core/model/Param'\nexport { defineDmmfProperty } from './core/runtimeDataModel'\nexport type * from './core/types/exported'\nexport type { ITXClientDenyList } from './core/types/exported/itxClientDenyList'\nexport { skip } from './core/types/exported/Skip'\nexport { makeTypedQueryFactory } from './core/types/exported/TypedSql'\nexport type { PrismaClientOptions } from './getPrismaClient'\nexport { getPrismaClient } from './getPrismaClient'\nexport { makeStrictEnum } from './strictEnum'\nexport { deserializeRawResult } from './utils/deserializeRawResults'\nexport { getRuntime } from './utils/getRuntime'\nexport {\n type BaseDMMF,\n dmmfToRuntimeDataModel,\n type GetPrismaClientConfig,\n type Operation,\n type RuntimeDataModel,\n} from '@prisma/client-common'\nexport { deserializeJsonResponse } from '@prisma/client-engine-runtime'\nexport type { RawValue, Value } from '@prisma/client-runtime-utils'\nexport type { AnyNullClass, DbNullClass, JsonNullClass } from '@prisma/client-runtime-utils'\nexport {\n PrismaClientInitializationError,\n PrismaClientKnownRequestError,\n PrismaClientRustPanicError,\n PrismaClientUnknownRequestError,\n PrismaClientValidationError,\n} from '@prisma/client-runtime-utils'\nexport { empty, join, raw, Sql, sql as sqltag } from '@prisma/client-runtime-utils'\nexport {\n AnyNull,\n DbNull,\n isAnyNull,\n isDbNull,\n isJsonNull,\n JsonNull,\n NullTypes,\n ObjectEnumValue,\n} from '@prisma/client-runtime-utils'\nexport { Decimal } from '@prisma/client-runtime-utils'\nexport { Debug } from '@prisma/debug'\nexport * as DMMF from '@prisma/dmmf'\nexport type { SqlDriverAdapterFactory } from '@prisma/driver-adapter-utils'\nexport { warnOnce } from '@prisma/internals'\nexport type {\n SqlCommenterContext,\n SqlCommenterPlugin,\n SqlCommenterQueryInfo,\n SqlCommenterSingleQueryInfo,\n SqlCommenterTags,\n} from '@prisma/sqlcommenter'\n"],
|
|
4
|
+
"sourcesContent": ["{\n \"name\": \"@prisma/engines-version\",\n \"version\": \"7.4.0-8.534ac5c12b9088d160899554cc8c11039ffb9738\",\n \"main\": \"index.js\",\n \"types\": \"index.d.ts\",\n \"license\": \"Apache-2.0\",\n \"author\": \"Tim Suchanek <suchanek@prisma.io>\",\n \"prisma\": {\n \"enginesVersion\": \"534ac5c12b9088d160899554cc8c11039ffb9738\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/prisma/engines-wrapper.git\",\n \"directory\": \"packages/engines-version\"\n },\n \"devDependencies\": {\n \"@types/node\": \"18.19.76\",\n \"typescript\": \"4.9.5\"\n },\n \"files\": [\n \"index.js\",\n \"index.d.ts\"\n ],\n \"scripts\": {\n \"build\": \"tsc -d\"\n }\n}", "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.enginesVersion = void 0;\nexports.enginesVersion = require('./package.json').prisma.enginesVersion;\n//# sourceMappingURL=index.js.map", "'use strict';\nmodule.exports = string => {\n\tconst match = string.match(/^[ \\t]*(?=\\S)/gm);\n\n\tif (!match) {\n\t\treturn 0;\n\t}\n\n\treturn match.reduce((r, a) => Math.min(r, a.length), Infinity);\n};\n", "'use strict';\n\nmodule.exports = (string, count = 1, options) => {\n\toptions = {\n\t\tindent: ' ',\n\t\tincludeEmptyLines: false,\n\t\t...options\n\t};\n\n\tif (typeof string !== 'string') {\n\t\tthrow new TypeError(\n\t\t\t`Expected \\`input\\` to be a \\`string\\`, got \\`${typeof string}\\``\n\t\t);\n\t}\n\n\tif (typeof count !== 'number') {\n\t\tthrow new TypeError(\n\t\t\t`Expected \\`count\\` to be a \\`number\\`, got \\`${typeof count}\\``\n\t\t);\n\t}\n\n\tif (typeof options.indent !== 'string') {\n\t\tthrow new TypeError(\n\t\t\t`Expected \\`options.indent\\` to be a \\`string\\`, got \\`${typeof options.indent}\\``\n\t\t);\n\t}\n\n\tif (count === 0) {\n\t\treturn string;\n\t}\n\n\tconst regex = options.includeEmptyLines ? /^/gm : /^(?!\\s*$)/gm;\n\n\treturn string.replace(regex, options.indent.repeat(count));\n};\n", "'use strict';\n\nmodule.exports = (options = {}) => {\n\tlet repoUrl;\n\tif (options.repoUrl) {\n\t\trepoUrl = options.repoUrl;\n\t} else if (options.user && options.repo) {\n\t\trepoUrl = `https://github.com/${options.user}/${options.repo}`;\n\t} else {\n\t\tthrow new Error('You need to specify either the `repoUrl` option or both the `user` and `repo` options');\n\t}\n\n\tconst url = new URL(`${repoUrl}/issues/new`);\n\n\tconst types = [\n\t\t'body',\n\t\t'title',\n\t\t'labels',\n\t\t'template',\n\t\t'milestone',\n\t\t'assignee',\n\t\t'projects'\n\t];\n\n\tfor (const type of types) {\n\t\tlet value = options[type];\n\t\tif (value === undefined) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tif (type === 'labels' || type === 'projects') {\n\t\t\tif (!Array.isArray(value)) {\n\t\t\t\tthrow new TypeError(`The \\`${type}\\` option should be an array`);\n\t\t\t}\n\n\t\t\tvalue = value.join(',');\n\t\t}\n\n\t\turl.searchParams.set(type, value);\n\t}\n\n\treturn url.toString();\n};\n\n// TODO: Remove this for the next major release\nmodule.exports.default = module.exports;\n", "'use strict';\nmodule.exports = (function()\n{\n function _min(d0, d1, d2, bx, ay)\n {\n return d0 < d1 || d2 < d1\n ? d0 > d2\n ? d2 + 1\n : d0 + 1\n : bx === ay\n ? d1\n : d1 + 1;\n }\n\n return function(a, b)\n {\n if (a === b) {\n return 0;\n }\n\n if (a.length > b.length) {\n var tmp = a;\n a = b;\n b = tmp;\n }\n\n var la = a.length;\n var lb = b.length;\n\n while (la > 0 && (a.charCodeAt(la - 1) === b.charCodeAt(lb - 1))) {\n la--;\n lb--;\n }\n\n var offset = 0;\n\n while (offset < la && (a.charCodeAt(offset) === b.charCodeAt(offset))) {\n offset++;\n }\n\n la -= offset;\n lb -= offset;\n\n if (la === 0 || lb < 3) {\n return lb;\n }\n\n var x = 0;\n var y;\n var d0;\n var d1;\n var d2;\n var d3;\n var dd;\n var dy;\n var ay;\n var bx0;\n var bx1;\n var bx2;\n var bx3;\n\n var vector = [];\n\n for (y = 0; y < la; y++) {\n vector.push(y + 1);\n vector.push(a.charCodeAt(offset + y));\n }\n\n var len = vector.length - 1;\n\n for (; x < lb - 3;) {\n bx0 = b.charCodeAt(offset + (d0 = x));\n bx1 = b.charCodeAt(offset + (d1 = x + 1));\n bx2 = b.charCodeAt(offset + (d2 = x + 2));\n bx3 = b.charCodeAt(offset + (d3 = x + 3));\n dd = (x += 4);\n for (y = 0; y < len; y += 2) {\n dy = vector[y];\n ay = vector[y + 1];\n d0 = _min(dy, d0, d1, bx0, ay);\n d1 = _min(d0, d1, d2, bx1, ay);\n d2 = _min(d1, d2, d3, bx2, ay);\n dd = _min(d2, d3, dd, bx3, ay);\n vector[y] = dd;\n d3 = d2;\n d2 = d1;\n d1 = d0;\n d0 = dy;\n }\n }\n\n for (; x < lb;) {\n bx0 = b.charCodeAt(offset + (d0 = x));\n dd = ++x;\n for (y = 0; y < len; y += 2) {\n dy = vector[y];\n vector[y] = dd = _min(dy, d0, dd, bx0, vector[y + 1]);\n d0 = dy;\n }\n }\n\n return dd;\n };\n})();\n\n", "import { BasicBuilder } from './BasicBuilder'\nimport type { KeyType } from './KeyType'\nimport { Writer } from './Writer'\n\nexport abstract class TypeBuilder implements BasicBuilder {\n // TODO(@SevInf): this should be replaced with precedence system that would\n // automatically add parenthesis where they are needed\n needsParenthesisWhenIndexed = false\n needsParenthesisInKeyof = false\n needsParenthesisInUnion = false\n needsParenthesisInIntersection = false\n\n abstract write(writer: Writer): void\n\n subKey(key: string): KeyType {\n // TODO: since we translating ESM to CommonJS during bundling, we\n // can't handle circular dependencies the same way ESM does. We have to delay KeyType import\n // to resolve it. Once we stop doing this, we can move this import to top of the file.\n const { KeyType } = require('./KeyType')\n return new KeyType(this, key)\n }\n\n writeIndexed(writer: Writer) {\n if (this.needsParenthesisWhenIndexed) {\n writer.write('(')\n }\n\n writer.write(this)\n\n if (this.needsParenthesisWhenIndexed) {\n writer.write(')')\n }\n }\n}\n", "import { TypeBuilder } from './TypeBuilder'\nimport { Writer } from './Writer'\n\nexport class KeyType extends TypeBuilder {\n constructor(\n public baseType: TypeBuilder,\n public key: string,\n ) {\n super()\n }\n write(writer: Writer): void {\n this.baseType.writeIndexed(writer)\n\n writer.write('[').write(`\"${this.key}\"`).write(']')\n }\n}\n\nexport function keyType(baseType: TypeBuilder, key: string) {\n return new KeyType(baseType, key)\n}\n", "/**\n * Internal assertion helpers.\n * @module\n */\n\n/** Asserts something is positive integer. */\nfunction anumber(n: number): void {\n if (!Number.isSafeInteger(n) || n < 0) throw new Error('positive integer expected, got ' + n);\n}\n\n/** Is number an Uint8Array? Copied from utils for perf. */\nfunction isBytes(a: unknown): a is Uint8Array {\n return a instanceof Uint8Array || (ArrayBuffer.isView(a) && a.constructor.name === 'Uint8Array');\n}\n\n/** Asserts something is Uint8Array. */\nfunction abytes(b: Uint8Array | undefined, ...lengths: number[]): void {\n if (!isBytes(b)) throw new Error('Uint8Array expected');\n if (lengths.length > 0 && !lengths.includes(b.length))\n throw new Error('Uint8Array expected of length ' + lengths + ', got length=' + b.length);\n}\n\n/** Hash interface. */\nexport type Hash = {\n (data: Uint8Array): Uint8Array;\n blockLen: number;\n outputLen: number;\n create: any;\n};\n\n/** Asserts something is hash */\nfunction ahash(h: Hash): void {\n if (typeof h !== 'function' || typeof h.create !== 'function')\n throw new Error('Hash should be wrapped by utils.wrapConstructor');\n anumber(h.outputLen);\n anumber(h.blockLen);\n}\n\n/** Asserts a hash instance has not been destroyed / finished */\nfunction aexists(instance: any, checkFinished = true): void {\n if (instance.destroyed) throw new Error('Hash instance has been destroyed');\n if (checkFinished && instance.finished) throw new Error('Hash#digest() has already been called');\n}\n\n/** Asserts output is properly-sized byte array */\nfunction aoutput(out: any, instance: any): void {\n abytes(out);\n const min = instance.outputLen;\n if (out.length < min) {\n throw new Error('digestInto() expects output buffer of length at least ' + min);\n }\n}\n\nexport { anumber, abytes, ahash, aexists, aoutput };\n", "/**\n * Internal helpers for u64. BigUint64Array is too slow as per 2025, so we implement it using Uint32Array.\n * @todo re-check https://issues.chromium.org/issues/42212588\n * @module\n */\nconst U32_MASK64 = /* @__PURE__ */ BigInt(2 ** 32 - 1);\nconst _32n = /* @__PURE__ */ BigInt(32);\n\nfunction fromBig(\n n: bigint,\n le = false\n): {\n h: number;\n l: number;\n} {\n if (le) return { h: Number(n & U32_MASK64), l: Number((n >> _32n) & U32_MASK64) };\n return { h: Number((n >> _32n) & U32_MASK64) | 0, l: Number(n & U32_MASK64) | 0 };\n}\n\nfunction split(lst: bigint[], le = false): Uint32Array[] {\n let Ah = new Uint32Array(lst.length);\n let Al = new Uint32Array(lst.length);\n for (let i = 0; i < lst.length; i++) {\n const { h, l } = fromBig(lst[i], le);\n [Ah[i], Al[i]] = [h, l];\n }\n return [Ah, Al];\n}\n\nconst toBig = (h: number, l: number): bigint => (BigInt(h >>> 0) << _32n) | BigInt(l >>> 0);\n// for Shift in [0, 32)\nconst shrSH = (h: number, _l: number, s: number): number => h >>> s;\nconst shrSL = (h: number, l: number, s: number): number => (h << (32 - s)) | (l >>> s);\n// Right rotate for Shift in [1, 32)\nconst rotrSH = (h: number, l: number, s: number): number => (h >>> s) | (l << (32 - s));\nconst rotrSL = (h: number, l: number, s: number): number => (h << (32 - s)) | (l >>> s);\n// Right rotate for Shift in (32, 64), NOTE: 32 is special case.\nconst rotrBH = (h: number, l: number, s: number): number => (h << (64 - s)) | (l >>> (s - 32));\nconst rotrBL = (h: number, l: number, s: number): number => (h >>> (s - 32)) | (l << (64 - s));\n// Right rotate for shift===32 (just swaps l&h)\nconst rotr32H = (_h: number, l: number): number => l;\nconst rotr32L = (h: number, _l: number): number => h;\n// Left rotate for Shift in [1, 32)\nconst rotlSH = (h: number, l: number, s: number): number => (h << s) | (l >>> (32 - s));\nconst rotlSL = (h: number, l: number, s: number): number => (l << s) | (h >>> (32 - s));\n// Left rotate for Shift in (32, 64), NOTE: 32 is special case.\nconst rotlBH = (h: number, l: number, s: number): number => (l << (s - 32)) | (h >>> (64 - s));\nconst rotlBL = (h: number, l: number, s: number): number => (h << (s - 32)) | (l >>> (64 - s));\n\n// JS uses 32-bit signed integers for bitwise operations which means we cannot\n// simple take carry out of low bit sum by shift, we need to use division.\nfunction add(\n Ah: number,\n Al: number,\n Bh: number,\n Bl: number\n): {\n h: number;\n l: number;\n} {\n const l = (Al >>> 0) + (Bl >>> 0);\n return { h: (Ah + Bh + ((l / 2 ** 32) | 0)) | 0, l: l | 0 };\n}\n// Addition with more than 2 elements\nconst add3L = (Al: number, Bl: number, Cl: number): number => (Al >>> 0) + (Bl >>> 0) + (Cl >>> 0);\nconst add3H = (low: number, Ah: number, Bh: number, Ch: number): number =>\n (Ah + Bh + Ch + ((low / 2 ** 32) | 0)) | 0;\nconst add4L = (Al: number, Bl: number, Cl: number, Dl: number): number =>\n (Al >>> 0) + (Bl >>> 0) + (Cl >>> 0) + (Dl >>> 0);\nconst add4H = (low: number, Ah: number, Bh: number, Ch: number, Dh: number): number =>\n (Ah + Bh + Ch + Dh + ((low / 2 ** 32) | 0)) | 0;\nconst add5L = (Al: number, Bl: number, Cl: number, Dl: number, El: number): number =>\n (Al >>> 0) + (Bl >>> 0) + (Cl >>> 0) + (Dl >>> 0) + (El >>> 0);\nconst add5H = (low: number, Ah: number, Bh: number, Ch: number, Dh: number, Eh: number): number =>\n (Ah + Bh + Ch + Dh + Eh + ((low / 2 ** 32) | 0)) | 0;\n\n// prettier-ignore\nexport {\n fromBig, split, toBig,\n shrSH, shrSL,\n rotrSH, rotrSL, rotrBH, rotrBL,\n rotr32H, rotr32L,\n rotlSH, rotlSL, rotlBH, rotlBL,\n add, add3L, add3H, add4L, add4H, add5H, add5L,\n};\n// prettier-ignore\nconst u64: { fromBig: typeof fromBig; split: typeof split; toBig: (h: number, l: number) => bigint; shrSH: (h: number, _l: number, s: number) => number; shrSL: (h: number, l: number, s: number) => number; rotrSH: (h: number, l: number, s: number) => number; rotrSL: (h: number, l: number, s: number) => number; rotrBH: (h: number, l: number, s: number) => number; rotrBL: (h: number, l: number, s: number) => number; rotr32H: (_h: number, l: number) => number; rotr32L: (h: number, _l: number) => number; rotlSH: (h: number, l: number, s: number) => number; rotlSL: (h: number, l: number, s: number) => number; rotlBH: (h: number, l: number, s: number) => number; rotlBL: (h: number, l: number, s: number) => number; add: typeof add; add3L: (Al: number, Bl: number, Cl: number) => number; add3H: (low: number, Ah: number, Bh: number, Ch: number) => number; add4L: (Al: number, Bl: number, Cl: number, Dl: number) => number; add4H: (low: number, Ah: number, Bh: number, Ch: number, Dh: number) => number; add5H: (low: number, Ah: number, Bh: number, Ch: number, Dh: number, Eh: number) => number; add5L: (Al: number, Bl: number, Cl: number, Dl: number, El: number) => number; } = {\n fromBig, split, toBig,\n shrSH, shrSL,\n rotrSH, rotrSL, rotrBH, rotrBL,\n rotr32H, rotr32L,\n rotlSH, rotlSL, rotlBH, rotlBL,\n add, add3L, add3H, add4L, add4H, add5H, add5L,\n};\nexport default u64;\n", "/**\n * Internal webcrypto alias.\n * We prefer WebCrypto aka globalThis.crypto, which exists in node.js 16+.\n * Falls back to Node.js built-in crypto for Node.js <=v14.\n * See utils.ts for details.\n * @module\n */\n// @ts-ignore\nimport * as nc from 'node:crypto';\nexport const crypto: any =\n nc && typeof nc === 'object' && 'webcrypto' in nc\n ? (nc.webcrypto as any)\n : nc && typeof nc === 'object' && 'randomBytes' in nc\n ? nc\n : undefined;\n", "/**\n * Utilities for hex, bytes, CSPRNG.\n * @module\n */\n/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */\n\n// We use WebCrypto aka globalThis.crypto, which exists in browsers and node.js 16+.\n// node.js versions earlier than v19 don't declare it in global scope.\n// For node.js, package.json#exports field mapping rewrites import\n// from `crypto` to `cryptoNode`, which imports native module.\n// Makes the utils un-importable in browsers without a bundler.\n// Once node.js 18 is deprecated (2025-04-30), we can just drop the import.\nimport { crypto } from '@noble/hashes/crypto';\nimport { abytes } from './_assert.js';\n// export { isBytes } from './_assert.js';\n// We can't reuse isBytes from _assert, because somehow this causes huge perf issues\nexport function isBytes(a: unknown): a is Uint8Array {\n return a instanceof Uint8Array || (ArrayBuffer.isView(a) && a.constructor.name === 'Uint8Array');\n}\n\n// prettier-ignore\nexport type TypedArray = Int8Array | Uint8ClampedArray | Uint8Array |\n Uint16Array | Int16Array | Uint32Array | Int32Array;\n\n// Cast array to different type\nexport function u8(arr: TypedArray): Uint8Array {\n return new Uint8Array(arr.buffer, arr.byteOffset, arr.byteLength);\n}\nexport function u32(arr: TypedArray): Uint32Array {\n return new Uint32Array(arr.buffer, arr.byteOffset, Math.floor(arr.byteLength / 4));\n}\n\n// Cast array to view\nexport function createView(arr: TypedArray): DataView {\n return new DataView(arr.buffer, arr.byteOffset, arr.byteLength);\n}\n\n/** The rotate right (circular right shift) operation for uint32 */\nexport function rotr(word: number, shift: number): number {\n return (word << (32 - shift)) | (word >>> shift);\n}\n/** The rotate left (circular left shift) operation for uint32 */\nexport function rotl(word: number, shift: number): number {\n return (word << shift) | ((word >>> (32 - shift)) >>> 0);\n}\n\n/** Is current platform little-endian? Most are. Big-Endian platform: IBM */\nexport const isLE: boolean = /* @__PURE__ */ (() =>\n new Uint8Array(new Uint32Array([0x11223344]).buffer)[0] === 0x44)();\n// The byte swap operation for uint32\nexport function byteSwap(word: number): number {\n return (\n ((word << 24) & 0xff000000) |\n ((word << 8) & 0xff0000) |\n ((word >>> 8) & 0xff00) |\n ((word >>> 24) & 0xff)\n );\n}\n/** Conditionally byte swap if on a big-endian platform */\nexport const byteSwapIfBE: (n: number) => number = isLE\n ? (n: number) => n\n : (n: number) => byteSwap(n);\n\n/** In place byte swap for Uint32Array */\nexport function byteSwap32(arr: Uint32Array): void {\n for (let i = 0; i < arr.length; i++) {\n arr[i] = byteSwap(arr[i]);\n }\n}\n\n// Array where index 0xf0 (240) is mapped to string 'f0'\nconst hexes = /* @__PURE__ */ Array.from({ length: 256 }, (_, i) =>\n i.toString(16).padStart(2, '0')\n);\n/**\n * Convert byte array to hex string.\n * @example bytesToHex(Uint8Array.from([0xca, 0xfe, 0x01, 0x23])) // 'cafe0123'\n */\nexport function bytesToHex(bytes: Uint8Array): string {\n abytes(bytes);\n // pre-caching improves the speed 6x\n let hex = '';\n for (let i = 0; i < bytes.length; i++) {\n hex += hexes[bytes[i]];\n }\n return hex;\n}\n\n// We use optimized technique to convert hex string to byte array\nconst asciis = { _0: 48, _9: 57, A: 65, F: 70, a: 97, f: 102 } as const;\nfunction asciiToBase16(ch: number): number | undefined {\n if (ch >= asciis._0 && ch <= asciis._9) return ch - asciis._0; // '2' => 50-48\n if (ch >= asciis.A && ch <= asciis.F) return ch - (asciis.A - 10); // 'B' => 66-(65-10)\n if (ch >= asciis.a && ch <= asciis.f) return ch - (asciis.a - 10); // 'b' => 98-(97-10)\n return;\n}\n\n/**\n * Convert hex string to byte array.\n * @example hexToBytes('cafe0123') // Uint8Array.from([0xca, 0xfe, 0x01, 0x23])\n */\nexport function hexToBytes(hex: string): Uint8Array {\n if (typeof hex !== 'string') throw new Error('hex string expected, got ' + typeof hex);\n const hl = hex.length;\n const al = hl / 2;\n if (hl % 2) throw new Error('hex string expected, got unpadded hex of length ' + hl);\n const array = new Uint8Array(al);\n for (let ai = 0, hi = 0; ai < al; ai++, hi += 2) {\n const n1 = asciiToBase16(hex.charCodeAt(hi));\n const n2 = asciiToBase16(hex.charCodeAt(hi + 1));\n if (n1 === undefined || n2 === undefined) {\n const char = hex[hi] + hex[hi + 1];\n throw new Error('hex string expected, got non-hex character \"' + char + '\" at index ' + hi);\n }\n array[ai] = n1 * 16 + n2; // multiply first octet, e.g. 'a3' => 10*16+3 => 160 + 3 => 163\n }\n return array;\n}\n\n/**\n * There is no setImmediate in browser and setTimeout is slow.\n * Call of async fn will return Promise, which will be fullfiled only on\n * next scheduler queue processing step and this is exactly what we need.\n */\nexport const nextTick = async (): Promise<void> => {};\n\n/** Returns control to thread each 'tick' ms to avoid blocking. */\nexport async function asyncLoop(\n iters: number,\n tick: number,\n cb: (i: number) => void\n): Promise<void> {\n let ts = Date.now();\n for (let i = 0; i < iters; i++) {\n cb(i);\n // Date.now() is not monotonic, so in case if clock goes backwards we return return control too\n const diff = Date.now() - ts;\n if (diff >= 0 && diff < tick) continue;\n await nextTick();\n ts += diff;\n }\n}\n\n// Global symbols in both browsers and Node.js since v11\n// See https://github.com/microsoft/TypeScript/issues/31535\ndeclare const TextEncoder: any;\n\n/**\n * Convert JS string to byte array.\n * @example utf8ToBytes('abc') // new Uint8Array([97, 98, 99])\n */\nexport function utf8ToBytes(str: string): Uint8Array {\n if (typeof str !== 'string') throw new Error('utf8ToBytes expected string, got ' + typeof str);\n return new Uint8Array(new TextEncoder().encode(str)); // https://bugzil.la/1681809\n}\n\n/** Accepted input of hash functions. Strings are converted to byte arrays. */\nexport type Input = Uint8Array | string;\n/**\n * Normalizes (non-hex) string or Uint8Array to Uint8Array.\n * Warning: when Uint8Array is passed, it would NOT get copied.\n * Keep in mind for future mutable operations.\n */\nexport function toBytes(data: Input): Uint8Array {\n if (typeof data === 'string') data = utf8ToBytes(data);\n abytes(data);\n return data;\n}\n\n/**\n * Copies several Uint8Arrays into one.\n */\nexport function concatBytes(...arrays: Uint8Array[]): Uint8Array {\n let sum = 0;\n for (let i = 0; i < arrays.length; i++) {\n const a = arrays[i];\n abytes(a);\n sum += a.length;\n }\n const res = new Uint8Array(sum);\n for (let i = 0, pad = 0; i < arrays.length; i++) {\n const a = arrays[i];\n res.set(a, pad);\n pad += a.length;\n }\n return res;\n}\n\n/** For runtime check if class implements interface */\nexport abstract class Hash<T extends Hash<T>> {\n abstract blockLen: number; // Bytes per block\n abstract outputLen: number; // Bytes in output\n abstract update(buf: Input): this;\n // Writes digest into buf\n abstract digestInto(buf: Uint8Array): void;\n abstract digest(): Uint8Array;\n /**\n * Resets internal state. Makes Hash instance unusable.\n * Reset is impossible for keyed hashes if key is consumed into state. If digest is not consumed\n * by user, they will need to manually call `destroy()` when zeroing is necessary.\n */\n abstract destroy(): void;\n /**\n * Clones hash instance. Unsafe: doesn't check whether `to` is valid. Can be used as `clone()`\n * when no options are passed.\n * Reasons to use `_cloneInto` instead of clone: 1) performance 2) reuse instance => all internal\n * buffers are overwritten => causes buffer overwrite which is used for digest in some cases.\n * There are no guarantees for clean-up because it's impossible in JS.\n */\n abstract _cloneInto(to?: T): T;\n // Safe version that clones internal state\n clone(): T {\n return this._cloneInto();\n }\n}\n\n/**\n * XOF: streaming API to read digest in chunks.\n * Same as 'squeeze' in keccak/k12 and 'seek' in blake3, but more generic name.\n * When hash used in XOF mode it is up to user to call '.destroy' afterwards, since we cannot\n * destroy state, next call can require more bytes.\n */\nexport type HashXOF<T extends Hash<T>> = Hash<T> & {\n xof(bytes: number): Uint8Array; // Read 'bytes' bytes from digest stream\n xofInto(buf: Uint8Array): Uint8Array; // read buf.length bytes from digest stream into buf\n};\n\ntype EmptyObj = {};\nexport function checkOpts<T1 extends EmptyObj, T2 extends EmptyObj>(\n defaults: T1,\n opts?: T2\n): T1 & T2 {\n if (opts !== undefined && {}.toString.call(opts) !== '[object Object]')\n throw new Error('Options should be object or undefined');\n const merged = Object.assign(defaults, opts);\n return merged as T1 & T2;\n}\n\n/** Hash function */\nexport type CHash = ReturnType<typeof wrapConstructor>;\n/** Hash function with output */\nexport type CHashO = ReturnType<typeof wrapConstructorWithOpts>;\n/** XOF with output */\nexport type CHashXO = ReturnType<typeof wrapXOFConstructorWithOpts>;\n\n/** Wraps hash function, creating an interface on top of it */\nexport function wrapConstructor<T extends Hash<T>>(\n hashCons: () => Hash<T>\n): {\n (msg: Input): Uint8Array;\n outputLen: number;\n blockLen: number;\n create(): Hash<T>;\n} {\n const hashC = (msg: Input): Uint8Array => hashCons().update(toBytes(msg)).digest();\n const tmp = hashCons();\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = () => hashCons();\n return hashC;\n}\n\nexport function wrapConstructorWithOpts<H extends Hash<H>, T extends Object>(\n hashCons: (opts?: T) => Hash<H>\n): {\n (msg: Input, opts?: T): Uint8Array;\n outputLen: number;\n blockLen: number;\n create(opts: T): Hash<H>;\n} {\n const hashC = (msg: Input, opts?: T): Uint8Array => hashCons(opts).update(toBytes(msg)).digest();\n const tmp = hashCons({} as T);\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = (opts: T) => hashCons(opts);\n return hashC;\n}\n\nexport function wrapXOFConstructorWithOpts<H extends HashXOF<H>, T extends Object>(\n hashCons: (opts?: T) => HashXOF<H>\n): {\n (msg: Input, opts?: T): Uint8Array;\n outputLen: number;\n blockLen: number;\n create(opts: T): HashXOF<H>;\n} {\n const hashC = (msg: Input, opts?: T): Uint8Array => hashCons(opts).update(toBytes(msg)).digest();\n const tmp = hashCons({} as T);\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = (opts: T) => hashCons(opts);\n return hashC;\n}\n\n/** Cryptographically secure PRNG. Uses internal OS-level `crypto.getRandomValues`. */\nexport function randomBytes(bytesLength = 32): Uint8Array {\n if (crypto && typeof crypto.getRandomValues === 'function') {\n return crypto.getRandomValues(new Uint8Array(bytesLength));\n }\n // Legacy Node.js compatibility\n if (crypto && typeof crypto.randomBytes === 'function') {\n return crypto.randomBytes(bytesLength);\n }\n throw new Error('crypto.getRandomValues must be defined');\n}\n", "/**\n * SHA3 (keccak) hash function, based on a new \"Sponge function\" design.\n * Different from older hashes, the internal state is bigger than output size.\n *\n * Check out [FIPS-202](https://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.202.pdf),\n * [Website](https://keccak.team/keccak.html),\n * [the differences between SHA-3 and Keccak](https://crypto.stackexchange.com/questions/15727/what-are-the-key-differences-between-the-draft-sha-3-standard-and-the-keccak-sub).\n *\n * Check out `sha3-addons` module for cSHAKE, k12, and others.\n * @module\n */\nimport { abytes, aexists, anumber, aoutput } from './_assert.js';\nimport { rotlBH, rotlBL, rotlSH, rotlSL, split } from './_u64.js';\nimport {\n byteSwap32,\n Hash,\n isLE,\n toBytes,\n u32,\n wrapConstructor,\n wrapXOFConstructorWithOpts,\n type CHash,\n type CHashXO,\n type HashXOF,\n type Input,\n} from './utils.js';\n\n// Various per round constants calculations\nconst SHA3_PI: number[] = [];\nconst SHA3_ROTL: number[] = [];\nconst _SHA3_IOTA: bigint[] = [];\nconst _0n = /* @__PURE__ */ BigInt(0);\nconst _1n = /* @__PURE__ */ BigInt(1);\nconst _2n = /* @__PURE__ */ BigInt(2);\nconst _7n = /* @__PURE__ */ BigInt(7);\nconst _256n = /* @__PURE__ */ BigInt(256);\nconst _0x71n = /* @__PURE__ */ BigInt(0x71);\nfor (let round = 0, R = _1n, x = 1, y = 0; round < 24; round++) {\n // Pi\n [x, y] = [y, (2 * x + 3 * y) % 5];\n SHA3_PI.push(2 * (5 * y + x));\n // Rotational\n SHA3_ROTL.push((((round + 1) * (round + 2)) / 2) % 64);\n // Iota\n let t = _0n;\n for (let j = 0; j < 7; j++) {\n R = ((R << _1n) ^ ((R >> _7n) * _0x71n)) % _256n;\n if (R & _2n) t ^= _1n << ((_1n << /* @__PURE__ */ BigInt(j)) - _1n);\n }\n _SHA3_IOTA.push(t);\n}\nconst [SHA3_IOTA_H, SHA3_IOTA_L] = /* @__PURE__ */ split(_SHA3_IOTA, true);\n\n// Left rotation (without 0, 32, 64)\nconst rotlH = (h: number, l: number, s: number) => (s > 32 ? rotlBH(h, l, s) : rotlSH(h, l, s));\nconst rotlL = (h: number, l: number, s: number) => (s > 32 ? rotlBL(h, l, s) : rotlSL(h, l, s));\n\n/** `keccakf1600` internal function, additionally allows to adjust round count. */\nexport function keccakP(s: Uint32Array, rounds: number = 24): void {\n const B = new Uint32Array(5 * 2);\n // NOTE: all indices are x2 since we store state as u32 instead of u64 (bigints to slow in js)\n for (let round = 24 - rounds; round < 24; round++) {\n // Theta \u03B8\n for (let x = 0; x < 10; x++) B[x] = s[x] ^ s[x + 10] ^ s[x + 20] ^ s[x + 30] ^ s[x + 40];\n for (let x = 0; x < 10; x += 2) {\n const idx1 = (x + 8) % 10;\n const idx0 = (x + 2) % 10;\n const B0 = B[idx0];\n const B1 = B[idx0 + 1];\n const Th = rotlH(B0, B1, 1) ^ B[idx1];\n const Tl = rotlL(B0, B1, 1) ^ B[idx1 + 1];\n for (let y = 0; y < 50; y += 10) {\n s[x + y] ^= Th;\n s[x + y + 1] ^= Tl;\n }\n }\n // Rho (\u03C1) and Pi (\u03C0)\n let curH = s[2];\n let curL = s[3];\n for (let t = 0; t < 24; t++) {\n const shift = SHA3_ROTL[t];\n const Th = rotlH(curH, curL, shift);\n const Tl = rotlL(curH, curL, shift);\n const PI = SHA3_PI[t];\n curH = s[PI];\n curL = s[PI + 1];\n s[PI] = Th;\n s[PI + 1] = Tl;\n }\n // Chi (\u03C7)\n for (let y = 0; y < 50; y += 10) {\n for (let x = 0; x < 10; x++) B[x] = s[y + x];\n for (let x = 0; x < 10; x++) s[y + x] ^= ~B[(x + 2) % 10] & B[(x + 4) % 10];\n }\n // Iota (\u03B9)\n s[0] ^= SHA3_IOTA_H[round];\n s[1] ^= SHA3_IOTA_L[round];\n }\n B.fill(0);\n}\n\n/** Keccak sponge function. */\nexport class Keccak extends Hash<Keccak> implements HashXOF<Keccak> {\n protected state: Uint8Array;\n protected pos = 0;\n protected posOut = 0;\n protected finished = false;\n protected state32: Uint32Array;\n protected destroyed = false;\n // NOTE: we accept arguments in bytes instead of bits here.\n constructor(\n public blockLen: number,\n public suffix: number,\n public outputLen: number,\n protected enableXOF = false,\n protected rounds: number = 24\n ) {\n super();\n // Can be passed from user as dkLen\n anumber(outputLen);\n // 1600 = 5x5 matrix of 64bit. 1600 bits === 200 bytes\n // 0 < blockLen < 200\n if (0 >= this.blockLen || this.blockLen >= 200)\n throw new Error('Sha3 supports only keccak-f1600 function');\n this.state = new Uint8Array(200);\n this.state32 = u32(this.state);\n }\n protected keccak(): void {\n if (!isLE) byteSwap32(this.state32);\n keccakP(this.state32, this.rounds);\n if (!isLE) byteSwap32(this.state32);\n this.posOut = 0;\n this.pos = 0;\n }\n update(data: Input): this {\n aexists(this);\n const { blockLen, state } = this;\n data = toBytes(data);\n const len = data.length;\n for (let pos = 0; pos < len; ) {\n const take = Math.min(blockLen - this.pos, len - pos);\n for (let i = 0; i < take; i++) state[this.pos++] ^= data[pos++];\n if (this.pos === blockLen) this.keccak();\n }\n return this;\n }\n protected finish(): void {\n if (this.finished) return;\n this.finished = true;\n const { state, suffix, pos, blockLen } = this;\n // Do the padding\n state[pos] ^= suffix;\n if ((suffix & 0x80) !== 0 && pos === blockLen - 1) this.keccak();\n state[blockLen - 1] ^= 0x80;\n this.keccak();\n }\n protected writeInto(out: Uint8Array): Uint8Array {\n aexists(this, false);\n abytes(out);\n this.finish();\n const bufferOut = this.state;\n const { blockLen } = this;\n for (let pos = 0, len = out.length; pos < len; ) {\n if (this.posOut >= blockLen) this.keccak();\n const take = Math.min(blockLen - this.posOut, len - pos);\n out.set(bufferOut.subarray(this.posOut, this.posOut + take), pos);\n this.posOut += take;\n pos += take;\n }\n return out;\n }\n xofInto(out: Uint8Array): Uint8Array {\n // Sha3/Keccak usage with XOF is probably mistake, only SHAKE instances can do XOF\n if (!this.enableXOF) throw new Error('XOF is not possible for this instance');\n return this.writeInto(out);\n }\n xof(bytes: number): Uint8Array {\n anumber(bytes);\n return this.xofInto(new Uint8Array(bytes));\n }\n digestInto(out: Uint8Array): Uint8Array {\n aoutput(out, this);\n if (this.finished) throw new Error('digest() was already called');\n this.writeInto(out);\n this.destroy();\n return out;\n }\n digest(): Uint8Array {\n return this.digestInto(new Uint8Array(this.outputLen));\n }\n destroy(): void {\n this.destroyed = true;\n this.state.fill(0);\n }\n _cloneInto(to?: Keccak): Keccak {\n const { blockLen, suffix, outputLen, rounds, enableXOF } = this;\n to ||= new Keccak(blockLen, suffix, outputLen, enableXOF, rounds);\n to.state32.set(this.state32);\n to.pos = this.pos;\n to.posOut = this.posOut;\n to.finished = this.finished;\n to.rounds = rounds;\n // Suffix can change in cSHAKE\n to.suffix = suffix;\n to.outputLen = outputLen;\n to.enableXOF = enableXOF;\n to.destroyed = this.destroyed;\n return to;\n }\n}\n\nconst gen = (suffix: number, blockLen: number, outputLen: number) =>\n wrapConstructor(() => new Keccak(blockLen, suffix, outputLen));\n\n/** SHA3-224 hash function. */\nexport const sha3_224: CHash = /* @__PURE__ */ gen(0x06, 144, 224 / 8);\n/** SHA3-256 hash function. Different from keccak-256. */\nexport const sha3_256: CHash = /* @__PURE__ */ gen(0x06, 136, 256 / 8);\n/** SHA3-384 hash function. */\nexport const sha3_384: CHash = /* @__PURE__ */ gen(0x06, 104, 384 / 8);\n/** SHA3-512 hash function. */\nexport const sha3_512: CHash = /* @__PURE__ */ gen(0x06, 72, 512 / 8);\n\n/** keccak-224 hash function. */\nexport const keccak_224: CHash = /* @__PURE__ */ gen(0x01, 144, 224 / 8);\n/** keccak-256 hash function. Different from SHA3-256. */\nexport const keccak_256: CHash = /* @__PURE__ */ gen(0x01, 136, 256 / 8);\n/** keccak-384 hash function. */\nexport const keccak_384: CHash = /* @__PURE__ */ gen(0x01, 104, 384 / 8);\n/** keccak-512 hash function. */\nexport const keccak_512: CHash = /* @__PURE__ */ gen(0x01, 72, 512 / 8);\n\nexport type ShakeOpts = { dkLen?: number };\n\nconst genShake = (suffix: number, blockLen: number, outputLen: number) =>\n wrapXOFConstructorWithOpts<HashXOF<Keccak>, ShakeOpts>(\n (opts: ShakeOpts = {}) =>\n new Keccak(blockLen, suffix, opts.dkLen === undefined ? outputLen : opts.dkLen, true)\n );\n\n/** SHAKE128 XOF with 128-bit security. */\nexport const shake128: CHashXO = /* @__PURE__ */ genShake(0x1f, 168, 128 / 8);\n/** SHAKE256 XOF with 256-bit security. */\nexport const shake256: CHashXO = /* @__PURE__ */ genShake(0x1f, 136, 256 / 8);\n", "/* global global, window, module */\nconst { sha3_512: sha3 } = require(\"@noble/hashes/sha3\");\n\nconst defaultLength = 24;\nconst bigLength = 32;\n\nconst createEntropy = (length = 4, random = Math.random) => {\n let entropy = \"\";\n\n while (entropy.length < length) {\n entropy = entropy + Math.floor(random() * 36).toString(36);\n }\n return entropy;\n};\n\n/*\n * Adapted from https://github.com/juanelas/bigint-conversion\n * MIT License Copyright (c) 2018 Juan Hern\u00E1ndez Serrano\n */\nfunction bufToBigInt(buf) {\n let bits = 8n;\n\n let value = 0n;\n for (const i of buf.values()) {\n const bi = BigInt(i);\n value = (value << bits) + bi;\n }\n return value;\n}\n\nconst hash = (input = \"\") => {\n // Drop the first character because it will bias the histogram\n // to the left.\n return bufToBigInt(sha3(input)).toString(36).slice(1);\n};\n\nconst alphabet = Array.from({ length: 26 }, (x, i) =>\n String.fromCharCode(i + 97)\n);\n\nconst randomLetter = (random) =>\n alphabet[Math.floor(random() * alphabet.length)];\n\n/*\nThis is a fingerprint of the host environment. It is used to help\nprevent collisions when generating ids in a distributed system.\nIf no global object is available, you can pass in your own, or fall back\non a random string.\n*/\nconst createFingerprint = ({\n globalObj = typeof global !== \"undefined\"\n ? global\n : typeof window !== \"undefined\"\n ? window\n : {},\n random = Math.random,\n} = {}) => {\n const globals = Object.keys(globalObj).toString();\n const sourceString = globals.length\n ? globals + createEntropy(bigLength, random)\n : createEntropy(bigLength, random);\n\n return hash(sourceString).substring(0, bigLength);\n};\n\nconst createCounter = (count) => () => {\n return count++;\n};\n\n// ~22k hosts before 50% chance of initial counter collision\n// with a remaining counter range of 9.0e+15 in JavaScript.\nconst initialCountMax = 476782367;\n\nconst init = ({\n // Fallback if the user does not pass in a CSPRNG. This should be OK\n // because we don't rely solely on the random number generator for entropy.\n // We also use the host fingerprint, current time, and a session counter.\n random = Math.random,\n counter = createCounter(Math.floor(random() * initialCountMax)),\n length = defaultLength,\n fingerprint = createFingerprint({ random }),\n} = {}) => {\n return function cuid2() {\n const firstLetter = randomLetter(random);\n\n // If we're lucky, the `.toString(36)` calls may reduce hashing rounds\n // by shortening the input to the hash function a little.\n const time = Date.now().toString(36);\n const count = counter().toString(36);\n\n // The salt should be long enough to be globally unique across the full\n // length of the hash. For simplicity, we use the same length as the\n // intended id output.\n const salt = createEntropy(length, random);\n const hashInput = `${time + salt + count + fingerprint}`;\n\n return `${firstLetter + hash(hashInput).substring(1, length)}`;\n };\n};\n\nconst createId = init();\n\nconst isCuid = (id, { minLength = 2, maxLength = bigLength } = {}) => {\n const length = id.length;\n const regex = /^[0-9a-z]+$/;\n\n try {\n if (\n typeof id === \"string\" &&\n length >= minLength &&\n length <= maxLength &&\n regex.test(id)\n )\n return true;\n } finally {\n }\n\n return false;\n};\n\nmodule.exports.getConstants = () => ({ defaultLength, bigLength });\nmodule.exports.init = init;\nmodule.exports.createId = createId;\nmodule.exports.bufToBigInt = bufToBigInt;\nmodule.exports.createCounter = createCounter;\nmodule.exports.createFingerprint = createFingerprint;\nmodule.exports.isCuid = isCuid;\n", "const { createId, init, getConstants, isCuid } = require(\"./src/index\");\n\nmodule.exports.createId = createId;\nmodule.exports.init = init;\nmodule.exports.getConstants = getConstants;\nmodule.exports.isCuid = isCuid;\n", "import { defineExtension } from './defineExtension'\nimport { getExtensionContext } from './getExtensionContext'\n\nexport { defineExtension }\nexport { getExtensionContext }\n", "import { Client } from '../../getPrismaClient'\nimport { ExtensionArgs } from '../types/exported/ExtensionArgs'\n\nexport function defineExtension(ext: ExtensionArgs | ((client: Client) => Client)) {\n if (typeof ext === 'function') {\n return ext\n }\n\n return (client: Client) => client.$extends(ext)\n}\n", "/*\n * Because we use a symbol to store the context, we need to merge the context\n * with the original this type. We manage the context via `getExtensionContext`\n * to circumvent the limitations of `this` inference in TS, while also providing\n * a unified API for context management in generic and non-generic extensions.\n */\n\n/* eslint-disable prettier/prettier */\nexport type Context<T> = T extends { [K: symbol]: { ctx: infer C } }\n ? C &\n T & {\n /**\n * @deprecated Use `$name` instead.\n */\n name?: string\n $name?: string\n $parent?: unknown\n }\n : T & {\n /**\n * @deprecated Use `$name` instead.\n */\n name?: string\n $name?: string\n $parent?: unknown\n }\n\nexport function getExtensionContext<T>(that: T) {\n return that as any as Context<T>\n}\n", "import { validator } from './validator'\n\n/*\n * /!\\ These exports are exposed to the user. Proceed with caution.\n *\n * TODO: Move more hardcoded utils from generation into here\n */\n\nexport { validator }\n", "import { Args, Operation } from '../types/exported/Public'\nimport { Exact } from '../types/exported/Utils'\n\nexport function validator<V>(): <S>(select: Exact<S, V>) => S\nexport function validator<C, M extends Exclude<keyof C, `$${string}`>, O extends keyof C[M] & Operation>(\n client: C,\n model: M,\n operation: O,\n): <S>(select: Exact<S, Args<C[M], O>>) => S\nexport function validator<\n C,\n M extends Exclude<keyof C, `$${string}`>,\n O extends keyof C[M] & Operation,\n P extends keyof Args<C[M], O>,\n>(client: C, model: M, operation: O, prop: P): <S>(select: Exact<S, Args<C[M], O>[P]>) => S\nexport function validator(..._args: any[]) {\n return (args: any) => args\n}\n", "type CacheEntry<V> = {\n value: V\n}\nexport class Cache<K, V> {\n private _map = new Map<K, CacheEntry<V>>()\n\n get(key: K): V | undefined {\n return this._map.get(key)?.value\n }\n\n set(key: K, value: V): void {\n this._map.set(key, { value })\n }\n\n getOrCreate(key: K, create: () => V): V {\n const cached = this._map.get(key)\n if (cached) {\n return cached.value\n }\n const value = create()\n this.set(key, value)\n return value\n }\n}\n", "/**\n * Converts the first character of a word to upper case.\n */\nexport function capitalize<T extends string>(self: T): Capitalize<T> {\n if (self.length === 0) return self as Capitalize<T>\n\n return (self[0].toUpperCase() + self.slice(1)) as Capitalize<T>\n}\n\n/**\n * Converts the first character of a word to lower case.\n */\nexport function uncapitalize<T extends string>(self: T): Uncapitalize<T> {\n return (self.substring(0, 1).toLowerCase() + self.substring(1)) as Uncapitalize<T>\n}\n", "export interface Dictionary<T> {\n [key: string]: T\n}\n\nexport function keyBy<P extends PropertyKey, T extends { [key in P]: string }>(\n collection: readonly T[],\n prop: P,\n): Dictionary<T> {\n const acc: Dictionary<T> = {}\n\n for (const obj of collection) {\n const key = obj[prop]\n acc[key] = obj\n }\n\n return acc\n}\n", "export type LazyProperty<T> = {\n get: () => T\n}\n\nexport function lazyProperty<T>(compute: () => T): LazyProperty<T> {\n let resultContainer: undefined | { value: T }\n\n return {\n get() {\n if (resultContainer) {\n return resultContainer.value\n }\n resultContainer = { value: compute() }\n return resultContainer.value\n },\n }\n}\n", "import type * as DMMF from '@prisma/dmmf'\n\nexport type RuntimeModel = Omit<DMMF.Model, 'name'>\nexport type RuntimeEnum = Omit<DMMF.DatamodelEnum, 'name'>\n\nexport type RuntimeDataModel = {\n readonly models: Record<string, RuntimeModel>\n readonly enums: Record<string, RuntimeEnum>\n readonly types: Record<string, RuntimeModel>\n}\n\nexport type PrunedRuntimeModel = {\n readonly dbName: RuntimeModel['dbName']\n readonly fields: Pick<RuntimeModel['fields'][number], 'name' | 'kind' | 'type' | 'relationName' | 'dbName'>[]\n}\n\nexport type PrunedRuntimeDataModel = {\n readonly models: Record<string, PrunedRuntimeModel>\n readonly enums: {}\n readonly types: {}\n}\n\nexport function dmmfToRuntimeDataModel(dmmfDataModel: DMMF.Datamodel): RuntimeDataModel {\n return {\n models: buildMapForRuntime(dmmfDataModel.models),\n enums: buildMapForRuntime(dmmfDataModel.enums),\n types: buildMapForRuntime(dmmfDataModel.types),\n }\n}\n\n/**\n * Minimal version of the runtime datamodel for the Client to work\n * @param runtimeDataModel\n * @returns\n */\nexport function pruneRuntimeDataModel({ models }: RuntimeDataModel) {\n const prunedModels: PrunedRuntimeDataModel['models'] = {}\n\n for (const modelName of Object.keys(models)) {\n prunedModels[modelName] = { fields: [], dbName: models[modelName].dbName }\n\n for (const { name, kind, type, relationName, dbName } of models[modelName].fields) {\n prunedModels[modelName].fields.push({ name, kind, type, relationName, dbName })\n }\n }\n\n return { models: prunedModels, enums: {}, types: {} }\n}\n\nfunction buildMapForRuntime<T extends { name: string }>(list: readonly T[]): Record<string, Omit<T, 'name'>> {\n const result: Record<string, Omit<T, 'name'>> = {}\n for (const { name, ...rest } of list) {\n result[name] = rest\n }\n return result\n}\n", "import { RuntimeDataModel, RuntimeModel, uncapitalize } from '@prisma/client-common'\nimport { isAnyNull, isDbNull, isJsonNull, ObjectEnumValue } from '@prisma/client-runtime-utils'\nimport { assertNever } from '@prisma/internals'\n\nimport { ErrorFormat } from '../../getPrismaClient'\nimport { CallSite } from '../../utils/CallSite'\nimport { isDate, isValidDate } from '../../utils/date'\nimport { isDecimalJsLike } from '../../utils/decimalJsLike'\nimport {\n JsonArgumentValue,\n JsonFieldSelection,\n JsonQuery,\n JsonQueryAction,\n JsonSelectionSet,\n OutputTypeDescription,\n RawTaggedValue,\n} from '../engines'\nimport { throwValidationException } from '../errorRendering/throwValidationException'\nimport { MergedExtensionsList } from '../extensions/MergedExtensionsList'\nimport { computeEngineSideOmissions, computeEngineSideSelection } from '../extensions/resultUtils'\nimport { isFieldRef } from '../model/FieldRef'\nimport { isParam } from '../model/Param'\nimport { isSkip, Skip } from '../types'\nimport {\n Action,\n JsArgs,\n JsInputValue,\n JsonConvertible,\n Omission,\n RawParameters,\n Selection,\n} from '../types/exported/JsApi'\nimport { ValidationError } from '../types/ValidationError'\n\nconst jsActionToProtocolAction: Record<Action, JsonQueryAction> = {\n findUnique: 'findUnique',\n findUniqueOrThrow: 'findUniqueOrThrow',\n findFirst: 'findFirst',\n findFirstOrThrow: 'findFirstOrThrow',\n findMany: 'findMany',\n count: 'aggregate',\n create: 'createOne',\n createMany: 'createMany',\n createManyAndReturn: 'createManyAndReturn',\n update: 'updateOne',\n updateMany: 'updateMany',\n updateManyAndReturn: 'updateManyAndReturn',\n upsert: 'upsertOne',\n delete: 'deleteOne',\n deleteMany: 'deleteMany',\n executeRaw: 'executeRaw',\n queryRaw: 'queryRaw',\n aggregate: 'aggregate',\n groupBy: 'groupBy',\n runCommandRaw: 'runCommandRaw',\n findRaw: 'findRaw',\n aggregateRaw: 'aggregateRaw',\n}\n\nexport type GlobalOmitOptions = {\n [modelName: string]: {\n [fieldName: string]: boolean\n }\n}\n\nexport type SerializeParams = {\n runtimeDataModel: RuntimeDataModel\n modelName?: string\n action: Action\n args?: JsArgs\n extensions?: MergedExtensionsList\n callsite?: CallSite\n clientMethod: string\n clientVersion: string\n errorFormat: ErrorFormat\n previewFeatures: string[]\n globalOmit?: GlobalOmitOptions\n wrapRawValues?: boolean\n}\n\nconst STRICT_UNDEFINED_ERROR_MESSAGE = 'explicitly `undefined` values are not allowed'\n\nexport function serializeJsonQuery({\n modelName,\n action,\n args,\n runtimeDataModel,\n extensions = MergedExtensionsList.empty(),\n callsite,\n clientMethod,\n errorFormat,\n clientVersion,\n previewFeatures,\n globalOmit,\n wrapRawValues,\n}: SerializeParams): JsonQuery {\n const context = new SerializeContext({\n runtimeDataModel,\n modelName,\n action,\n rootArgs: args,\n callsite,\n extensions,\n selectionPath: [],\n argumentPath: [],\n originalMethod: clientMethod,\n errorFormat,\n clientVersion,\n previewFeatures,\n globalOmit,\n wrapRawValues,\n })\n return {\n modelName,\n action: jsActionToProtocolAction[action],\n query: serializeFieldSelection(args, context),\n }\n}\n\nfunction serializeFieldSelection(\n { select, include, ...args }: JsArgs = {},\n context: SerializeContext,\n): JsonFieldSelection {\n const omit = args.omit\n delete args.omit\n return {\n arguments: serializeArgumentsObject(args, context),\n selection: serializeSelectionSet(select, include, omit, context),\n }\n}\n\nfunction serializeSelectionSet(\n select: Selection | undefined,\n include: Selection | undefined,\n omit: Omission | undefined,\n context: SerializeContext,\n): JsonSelectionSet {\n if (select) {\n if (include) {\n context.throwValidationError({\n kind: 'MutuallyExclusiveFields',\n firstField: 'include',\n secondField: 'select',\n selectionPath: context.getSelectionPath(),\n })\n } else if (omit) {\n context.throwValidationError({\n kind: 'MutuallyExclusiveFields',\n firstField: 'omit',\n secondField: 'select',\n selectionPath: context.getSelectionPath(),\n })\n }\n return createExplicitSelection(select, context)\n }\n\n return createImplicitSelection(context, include, omit)\n}\n\nfunction createImplicitSelection(\n context: SerializeContext,\n include: Selection | undefined,\n omit: Omission | undefined,\n) {\n const selectionSet: JsonSelectionSet = {}\n\n if (context.modelOrType && !context.isRawAction()) {\n selectionSet.$composites = true\n selectionSet.$scalars = true\n }\n\n if (include) {\n addIncludedRelations(selectionSet, include, context)\n }\n\n omitFields(selectionSet, omit, context)\n\n return selectionSet\n}\n\nfunction addIncludedRelations(selectionSet: JsonSelectionSet, include: Selection, context: SerializeContext) {\n for (const [key, value] of Object.entries(include)) {\n if (isSkip(value)) {\n continue\n }\n const nestedContext = context.nestSelection(key)\n validateSelectionForUndefined(value, nestedContext)\n if (value === false || value === undefined) {\n selectionSet[key] = false\n continue\n }\n\n const field = context.findField(key)\n if (field && field.kind !== 'object') {\n context.throwValidationError({\n kind: 'IncludeOnScalar',\n selectionPath: context.getSelectionPath().concat(key),\n outputType: context.getOutputTypeDescription(),\n })\n }\n if (field) {\n selectionSet[key] = serializeFieldSelection(value === true ? {} : value, nestedContext)\n continue\n }\n\n if (value === true) {\n selectionSet[key] = true\n continue\n }\n\n // value is an object, field is unknown\n // this can either be user error (in that case, qe will respond with an error)\n // or virtual field not present on datamodel (like `_count`).\n // Since we don't know which one cast is, we still attempt to serialize selection\n selectionSet[key] = serializeFieldSelection(value, nestedContext)\n }\n}\n\nfunction omitFields(selectionSet: JsonSelectionSet, localOmit: Omission | undefined, context: SerializeContext) {\n const computedFields = context.getComputedFields()\n const combinedOmits = { ...context.getGlobalOmit(), ...localOmit }\n const omitWithComputedFields = computeEngineSideOmissions(combinedOmits, computedFields)\n for (const [key, value] of Object.entries(omitWithComputedFields)) {\n if (isSkip(value)) {\n continue\n }\n validateSelectionForUndefined(value, context.nestSelection(key))\n const field = context.findField(key)\n if (computedFields?.[key] && !field) {\n continue\n }\n selectionSet[key] = !value\n }\n}\n\nfunction createExplicitSelection(select: Selection, context: SerializeContext) {\n const selectionSet: JsonSelectionSet = {}\n const computedFields = context.getComputedFields()\n const selectWithComputedFields = computeEngineSideSelection(select, computedFields)\n\n for (const [key, value] of Object.entries(selectWithComputedFields)) {\n if (isSkip(value)) {\n continue\n }\n const nestedContext = context.nestSelection(key)\n validateSelectionForUndefined(value, nestedContext)\n const field = context.findField(key)\n if (computedFields?.[key] && !field) {\n continue\n }\n if (value === false || value === undefined || isSkip(value)) {\n selectionSet[key] = false\n continue\n }\n if (value === true) {\n if (field?.kind === 'object') {\n selectionSet[key] = serializeFieldSelection({}, nestedContext)\n } else {\n selectionSet[key] = true\n }\n continue\n }\n selectionSet[key] = serializeFieldSelection(value, nestedContext)\n }\n return selectionSet\n}\n\nfunction serializeArgumentsValue(\n jsValue: Exclude<JsInputValue, undefined | Skip>,\n context: SerializeContext,\n): JsonArgumentValue {\n if (jsValue === null) {\n return null\n }\n\n if (typeof jsValue === 'string' || typeof jsValue === 'number' || typeof jsValue === 'boolean') {\n return jsValue\n }\n\n if (typeof jsValue === 'bigint') {\n return { $type: 'BigInt', value: String(jsValue) }\n }\n\n if (isDate(jsValue)) {\n if (isValidDate(jsValue)) {\n return { $type: 'DateTime', value: jsValue.toISOString() }\n } else {\n context.throwValidationError({\n kind: 'InvalidArgumentValue',\n selectionPath: context.getSelectionPath(),\n argumentPath: context.getArgumentPath(),\n argument: {\n name: context.getArgumentName(),\n typeNames: ['Date'],\n },\n underlyingError: 'Provided Date object is invalid',\n })\n }\n }\n\n if (isParam(jsValue)) {\n return { $type: 'Param', value: jsValue.name }\n }\n\n if (isFieldRef(jsValue)) {\n return { $type: 'FieldRef', value: { _ref: jsValue.name, _container: jsValue.modelName } }\n }\n\n if (Array.isArray(jsValue)) {\n return serializeArgumentsArray(jsValue, context)\n }\n\n if (ArrayBuffer.isView(jsValue)) {\n const { buffer, byteOffset, byteLength } = jsValue\n // TODO(perf): get rid of this conversion\n return { $type: 'Bytes', value: Buffer.from(buffer, byteOffset, byteLength).toString('base64') }\n }\n\n if (isRawParameters(jsValue)) {\n return jsValue.values\n }\n\n if (isDecimalJsLike(jsValue)) {\n return { $type: 'Decimal', value: jsValue.toFixed() }\n }\n\n if (jsValue instanceof ObjectEnumValue) {\n if (!isDbNull(jsValue) && !isJsonNull(jsValue) && !isAnyNull(jsValue)) {\n throw new Error('Invalid ObjectEnumValue')\n }\n return { $type: 'Enum', value: jsValue._getName() }\n }\n\n if (isJSONConvertible(jsValue)) {\n return jsValue.toJSON() as JsonArgumentValue\n }\n\n if (typeof jsValue === 'object') {\n return serializeArgumentsObject(jsValue, context)\n }\n\n context.throwValidationError({\n kind: 'InvalidArgumentValue',\n selectionPath: context.getSelectionPath(),\n argumentPath: context.getArgumentPath(),\n argument: {\n name: context.getArgumentName(),\n typeNames: [],\n },\n underlyingError: `We could not serialize ${Object.prototype.toString.call(\n jsValue,\n )} value. Serialize the object to JSON or implement a \".toJSON()\" method on it`,\n })\n}\n\nfunction serializeArgumentsObject(\n object: Record<string, JsInputValue>,\n context: SerializeContext,\n): Record<string, JsonArgumentValue> | RawTaggedValue {\n if (context.shouldWrapRawValues()) {\n if (object['$type']) {\n return { $type: 'Raw', value: object }\n }\n }\n const result: Record<string, JsonArgumentValue> = {}\n for (const key in object) {\n const value = object[key]\n const nestedContext = context.nestArgument(key)\n if (isSkip(value)) {\n continue\n }\n if (value !== undefined) {\n result[key] = serializeArgumentsValue(value, nestedContext)\n } else if (context.isPreviewFeatureOn('strictUndefinedChecks')) {\n context.throwValidationError({\n kind: 'InvalidArgumentValue',\n argumentPath: nestedContext.getArgumentPath(),\n selectionPath: context.getSelectionPath(),\n argument: { name: context.getArgumentName(), typeNames: [] },\n underlyingError: STRICT_UNDEFINED_ERROR_MESSAGE,\n })\n }\n }\n return result\n}\n\nfunction serializeArgumentsArray(array: JsInputValue[], context: SerializeContext): JsonArgumentValue[] {\n const result: JsonArgumentValue[] = []\n for (let i = 0; i < array.length; i++) {\n const itemContext = context.nestArgument(String(i))\n const value = array[i]\n if (value === undefined || isSkip(value)) {\n const valueName = value === undefined ? 'undefined' : `Prisma.skip`\n context.throwValidationError({\n kind: 'InvalidArgumentValue',\n selectionPath: itemContext.getSelectionPath(),\n argumentPath: itemContext.getArgumentPath(),\n argument: {\n name: `${context.getArgumentName()}[${i}]`,\n typeNames: [],\n },\n underlyingError: `Can not use \\`${valueName}\\` value within array. Use \\`null\\` or filter out \\`${valueName}\\` values`,\n })\n }\n result.push(serializeArgumentsValue(value, itemContext))\n }\n return result\n}\n\nfunction isRawParameters(value: JsInputValue): value is RawParameters {\n return typeof value === 'object' && value !== null && value['__prismaRawParameters__'] === true\n}\n\nfunction isJSONConvertible(value: JsInputValue): value is JsonConvertible {\n return typeof value === 'object' && value !== null && typeof value['toJSON'] === 'function'\n}\n\nfunction validateSelectionForUndefined(value: unknown, context: SerializeContext) {\n if (value === undefined && context.isPreviewFeatureOn('strictUndefinedChecks')) {\n context.throwValidationError({\n kind: 'InvalidSelectionValue',\n selectionPath: context.getSelectionPath(),\n underlyingError: STRICT_UNDEFINED_ERROR_MESSAGE,\n })\n }\n}\n\ntype ContextParams = {\n runtimeDataModel: RuntimeDataModel\n originalMethod: string\n rootArgs: JsArgs | undefined\n extensions: MergedExtensionsList\n selectionPath: string[]\n argumentPath: string[]\n modelName?: string\n action: Action\n callsite?: CallSite\n errorFormat: ErrorFormat\n clientVersion: string\n previewFeatures: string[]\n globalOmit?: GlobalOmitOptions\n wrapRawValues?: boolean\n}\n\nclass SerializeContext {\n public readonly modelOrType: RuntimeModel | undefined\n constructor(private params: ContextParams) {\n if (this.params.modelName) {\n // TODO: throw if not found\n this.modelOrType =\n this.params.runtimeDataModel.models[this.params.modelName] ??\n this.params.runtimeDataModel.types[this.params.modelName]\n }\n }\n\n throwValidationError(error: ValidationError): never {\n throwValidationException({\n errors: [error],\n originalMethod: this.params.originalMethod,\n args: this.params.rootArgs ?? {},\n callsite: this.params.callsite,\n errorFormat: this.params.errorFormat,\n clientVersion: this.params.clientVersion,\n globalOmit: this.params.globalOmit,\n })\n }\n\n getSelectionPath() {\n return this.params.selectionPath\n }\n\n getArgumentPath() {\n return this.params.argumentPath\n }\n\n getArgumentName() {\n return this.params.argumentPath[this.params.argumentPath.length - 1]\n }\n\n getOutputTypeDescription(): OutputTypeDescription | undefined {\n if (!this.params.modelName || !this.modelOrType) {\n return undefined\n }\n return {\n name: this.params.modelName,\n fields: this.modelOrType.fields.map((field) => ({\n name: field.name,\n typeName: 'boolean',\n isRelation: field.kind === 'object',\n })),\n }\n }\n\n isRawAction() {\n return ['executeRaw', 'queryRaw', 'runCommandRaw', 'findRaw', 'aggregateRaw'].includes(this.params.action)\n }\n\n isPreviewFeatureOn(previewFeature: string) {\n return this.params.previewFeatures.includes(previewFeature)\n }\n\n shouldWrapRawValues(): boolean {\n return this.params.wrapRawValues ?? false\n }\n\n getComputedFields() {\n if (!this.params.modelName) {\n return undefined\n }\n\n return this.params.extensions.getAllComputedFields(this.params.modelName)\n }\n\n findField(name: string) {\n return this.modelOrType?.fields.find((field) => field.name === name)\n }\n\n nestSelection(fieldName: string) {\n const field = this.findField(fieldName)\n const modelName = field?.kind === 'object' ? field.type : undefined\n\n return new SerializeContext({\n ...this.params,\n modelName,\n selectionPath: this.params.selectionPath.concat(fieldName),\n })\n }\n\n getGlobalOmit(): Record<string, boolean> {\n if (this.params.modelName && this.shouldApplyGlobalOmit()) {\n return this.params.globalOmit?.[uncapitalize(this.params.modelName)] ?? {}\n }\n return {}\n }\n\n shouldApplyGlobalOmit(): boolean {\n switch (this.params.action) {\n case 'findFirst':\n case 'findFirstOrThrow':\n case 'findUniqueOrThrow':\n case 'findMany':\n case 'upsert':\n case 'findUnique':\n case 'createManyAndReturn':\n case 'create':\n case 'update':\n case 'updateManyAndReturn':\n case 'delete':\n return true\n case 'executeRaw':\n case 'aggregateRaw':\n case 'runCommandRaw':\n case 'findRaw':\n case 'createMany':\n case 'deleteMany':\n case 'groupBy':\n case 'updateMany':\n case 'count':\n case 'aggregate':\n case 'queryRaw':\n return false\n default:\n assertNever(this.params.action, 'Unknown action')\n }\n }\n\n nestArgument(fieldName: string) {\n return new SerializeContext({\n ...this.params,\n argumentPath: this.params.argumentPath.concat(fieldName),\n })\n }\n}\n", "let FORCE_COLOR, NODE_DISABLE_COLORS, NO_COLOR, TERM, isTTY=true;\nif (typeof process !== 'undefined') {\n\t({ FORCE_COLOR, NODE_DISABLE_COLORS, NO_COLOR, TERM } = process.env || {});\n\tisTTY = process.stdout && process.stdout.isTTY;\n}\n\nexport const $ = {\n\tenabled: !NODE_DISABLE_COLORS && NO_COLOR == null && TERM !== 'dumb' && (\n\t\tFORCE_COLOR != null && FORCE_COLOR !== '0' || isTTY\n\t)\n}\n\nfunction init(x, y) {\n\tlet rgx = new RegExp(`\\\\x1b\\\\[${y}m`, 'g');\n\tlet open = `\\x1b[${x}m`, close = `\\x1b[${y}m`;\n\n\treturn function (txt) {\n\t\tif (!$.enabled || txt == null) return txt;\n\t\treturn open + (!!~(''+txt).indexOf(close) ? txt.replace(rgx, close + open) : txt) + close;\n\t};\n}\n\n// modifiers\nexport const reset = init(0, 0);\nexport const bold = init(1, 22);\nexport const dim = init(2, 22);\nexport const italic = init(3, 23);\nexport const underline = init(4, 24);\nexport const inverse = init(7, 27);\nexport const hidden = init(8, 28);\nexport const strikethrough = init(9, 29);\n\n// colors\nexport const black = init(30, 39);\nexport const red = init(31, 39);\nexport const green = init(32, 39);\nexport const yellow = init(33, 39);\nexport const blue = init(34, 39);\nexport const magenta = init(35, 39);\nexport const cyan = init(36, 39);\nexport const white = init(37, 39);\nexport const gray = init(90, 39);\nexport const grey = init(90, 39);\n\n// background colors\nexport const bgBlack = init(40, 49);\nexport const bgRed = init(41, 49);\nexport const bgGreen = init(42, 49);\nexport const bgYellow = init(43, 49);\nexport const bgBlue = init(44, 49);\nexport const bgMagenta = init(45, 49);\nexport const bgCyan = init(46, 49);\nexport const bgWhite = init(47, 49);\n", "import * as kleur from 'kleur/colors'\nimport { bold } from 'kleur/colors'\n\nconst MAX_ARGS_HISTORY = 100\nconst COLORS = ['green', 'yellow', 'blue', 'magenta', 'cyan', 'red']\n\nconst argsHistory: [namespace: string, ...unknown[]][] = []\nlet lastTimestamp = Date.now()\nlet lastColor = 0\n\nconst processEnv = typeof process !== 'undefined' ? process.env : {}\n\nglobalThis.DEBUG ??= processEnv.DEBUG ?? ''\nglobalThis.DEBUG_COLORS ??= processEnv.DEBUG_COLORS ? processEnv.DEBUG_COLORS === 'true' : true\n\n/**\n * Top-level utilities to configure the debug module.\n *\n * @example\n * ```ts\n * import Debug from '@prisma/debug'\n * Debug.enable('prisma:client')\n * const debug = Debug('prisma:client')\n * debug('Hello World')\n * ```\n */\nconst topProps = {\n enable(namespace: any) {\n if (typeof namespace === 'string') {\n globalThis.DEBUG = namespace\n }\n },\n disable() {\n const prev = globalThis.DEBUG\n globalThis.DEBUG = ''\n return prev\n },\n // this is the core logic to check if logging should happen or not\n enabled(namespace: string) {\n // these are the namespaces that we are listening to in DEBUG=...\n const listenedNamespaces: string[] = globalThis.DEBUG.split(',').map((s: string) => {\n return s.replace(/[.+?^${}()|[\\]\\\\]/g, '\\\\$&') // escape regex except \"*\"\n })\n\n // we take incoming namespaces and check then against listened\n const isListened = listenedNamespaces.some((listenedNamespace) => {\n if (listenedNamespace === '' || listenedNamespace[0] === '-') return false\n\n return namespace.match(RegExp(listenedNamespace.split('*').join('.*') + '$'))\n })\n\n // we take incoming namespaces and check then against excluded\n const isExcluded = listenedNamespaces.some((listenedNamespace) => {\n if (listenedNamespace === '' || listenedNamespace[0] !== '-') return false\n\n return namespace.match(RegExp(listenedNamespace.slice(1).split('*').join('.*') + '$'))\n })\n\n return isListened && !isExcluded\n },\n log: (...args: string[]) => {\n const [namespace, format, ...rest] = args\n // Note: `console.warn` / `console.log` use `util.format` internally, so they can handle\n // `printf`-style string interpolation.\n const logWithFormatting = console.warn ?? console.log\n\n // console only formats first arg, concat ns+format\n logWithFormatting(`${namespace} ${format}`, ...rest)\n },\n formatters: {}, // not implemented\n}\n\n/**\n * Create a new debug instance with the given namespace.\n *\n * @example\n * ```ts\n * import Debug from '@prisma/debug'\n * const debug = Debug('prisma:client')\n * debug('Hello World')\n * ```\n */\nfunction debugCreate(namespace: string) {\n const instanceProps = {\n color: COLORS[lastColor++ % COLORS.length],\n enabled: topProps.enabled(namespace),\n namespace: namespace,\n log: topProps.log,\n extend: () => {}, // not implemented\n }\n\n const debugCall = (...args: any[]) => {\n const { enabled, namespace, color, log } = instanceProps\n\n // we push the args to our history of args\n if (args.length !== 0) {\n argsHistory.push([namespace, ...args])\n }\n\n // if it is too big, then we remove some\n if (argsHistory.length > MAX_ARGS_HISTORY) {\n argsHistory.shift()\n }\n\n if (topProps.enabled(namespace) || enabled) {\n const stringArgs = args.map((arg) => {\n if (typeof arg === 'string') {\n return arg\n }\n\n return safeStringify(arg)\n })\n\n const ms = `+${Date.now() - lastTimestamp}ms`\n lastTimestamp = Date.now()\n\n if (globalThis.DEBUG_COLORS) {\n log(kleur[color](bold(namespace)), ...stringArgs, kleur[color](ms))\n } else {\n log(namespace, ...stringArgs, ms)\n }\n }\n }\n\n return new Proxy(debugCall, {\n get: (_, prop) => instanceProps[prop],\n set: (_, prop, value) => (instanceProps[prop] = value),\n }) as typeof debugCall & typeof instanceProps\n}\n\nconst Debug = new Proxy(debugCreate, {\n get: (_, prop) => topProps[prop],\n set: (_, prop, value) => (topProps[prop] = value),\n}) as typeof debugCreate & typeof topProps\n\nfunction safeStringify(value: any, indent = 2) {\n const cache = new Set<any>()\n\n return JSON.stringify(\n value,\n (key, value) => {\n if (typeof value === 'object' && value !== null) {\n if (cache.has(value)) {\n return `[Circular *]`\n }\n\n cache.add(value)\n } else if (typeof value === 'bigint') {\n return value.toString()\n }\n\n return value\n },\n indent,\n )\n}\n\n/**\n * We can get the logs for all the last {@link MAX_ARGS_HISTORY} ${@link debugCall} that\n * have happened in the different packages. Useful to generate error report links.\n * @see https://stackoverflow.com/questions/417142/what-is-the-maximum-length-of-a-url-in-different-browsers\n * @param numChars\n * @returns\n */\nexport function getLogs(numChars = 7500): string {\n const logs = argsHistory\n .map(([namespace, ...args]) => {\n return `${namespace} ${args\n .map((arg) => {\n if (typeof arg === 'string') {\n return arg\n } else {\n return JSON.stringify(arg)\n }\n })\n .join(' ')}`\n })\n .join('\\n')\n\n if (logs.length < numChars) {\n return logs\n }\n\n return logs.slice(-numChars)\n}\n\nexport function clearLogs() {\n argsHistory.length = 0\n}\n\nexport { Debug }\nexport default Debug\n", "import minIndent from 'min-indent';\n\nexport default function stripIndent(string) {\n\tconst indent = minIndent(string);\n\n\tif (indent === 0) {\n\t\treturn string;\n\t}\n\n\tconst regex = new RegExp(`^[ \\\\t]{${indent}}`, 'gm');\n\n\treturn string.replace(regex, '');\n}\n", "export const PRISMA_POSTGRES_PROVIDER = 'prisma+postgres'\n\nexport const PRISMA_POSTGRES_PROTOCOL = `${PRISMA_POSTGRES_PROVIDER}:`\n\ndeclare const prismaPostgresBrand: unique symbol\ndeclare const prismaPostgresDevBrand: unique symbol\n\nexport type PrismaPostgresUrl<T extends string | URL> = T & {\n readonly [prismaPostgresBrand]: true\n}\n\nexport type PrismaPostgresDevUrl<T extends string | URL> = PrismaPostgresUrl<T> & {\n readonly [prismaPostgresDevBrand]: true\n}\n\nexport function isPrismaPostgres<T extends string | URL>(\n connectionString?: T,\n): connectionString is PrismaPostgresUrl<T> {\n return connectionString?.toString().startsWith(`${PRISMA_POSTGRES_PROTOCOL}//`) ?? false\n}\n\nexport function isPrismaPostgresDev<T extends string | URL>(\n connectionString?: T,\n): connectionString is PrismaPostgresDevUrl<T> {\n if (!isPrismaPostgres(connectionString)) {\n return false\n }\n\n const { host } = new URL(connectionString)\n\n return host.includes('localhost') || host.includes('127.0.0.1') || host.includes('[::1]')\n}\n", "import { blue, cyan, red, yellow } from 'kleur/colors'\n\nexport const tags = {\n error: red('prisma:error'),\n warn: yellow('prisma:warn'),\n info: cyan('prisma:info'),\n query: blue('prisma:query'),\n}\nexport const should = {\n warn: () => !process.env.PRISMA_DISABLE_WARNINGS,\n}\nexport function log(...data: any[]) {\n console.log(...data)\n}\nexport function warn(message: any, ...optionalParams: any[]) {\n if (should.warn()) {\n console.warn(`${tags.warn} ${message}`, ...optionalParams)\n }\n}\nexport function info(message: any, ...optionalParams: any[]) {\n console.info(`${tags.info} ${message}`, ...optionalParams)\n}\nexport function error(message: any, ...optionalParams: any[]) {\n console.error(`${tags.error} ${message}`, ...optionalParams)\n}\nexport function query(message: any, ...optionalParams: any[]) {\n console.log(`${tags.query} ${message}`, ...optionalParams)\n}\n", "/**\n * Utility function to ensure exhaustive checks for union types.\n *\n * @example\n * ```ts\n * declare const fruit: 'Apple' | 'Orange'\n *\n * switch (fruit) {\n * case 'Apple:\n * // do apple things\n * break;\n * case 'Orange:\n * // do orange things\n * break;\n * default:\n * // in case `fruit` type will expand in the future,\n * // we'll get a compile-time error here, listing all unhandled\n * // cases\n * assertNever(fruit, 'Unknown fruit')\n * }\n * ```\n * @param arg variable of the any union type. By the time `assertNever` is called\n * all possible cases of this union must already be handled\n * @param errorMessage error message to throw in runtime. Normally, should never happen\n * unless compile-time check is skipped\n */\nexport function assertNever(arg: never, errorMessage: string): never {\n throw new Error(errorMessage)\n}\n", "export default function ansiRegex({onlyFirst = false} = {}) {\n\t// Valid string terminator sequences are BEL, ESC\\, and 0x9c\n\tconst ST = '(?:\\\\u0007|\\\\u001B\\\\u005C|\\\\u009C)';\n\tconst pattern = [\n\t\t`[\\\\u001B\\\\u009B][[\\\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\\\d\\\\/#&.:=?%@~_]+)*|[a-zA-Z\\\\d]+(?:;[-a-zA-Z\\\\d\\\\/#&.:=?%@~_]*)*)?${ST})`,\n\t\t'(?:(?:\\\\d{1,4}(?:;\\\\d{0,4})*)?[\\\\dA-PR-TZcf-nq-uy=><~]))',\n\t].join('|');\n\n\treturn new RegExp(pattern, onlyFirst ? undefined : 'g');\n}\n", "import ansiRegex from 'ansi-regex';\n\nconst regex = ansiRegex();\n\nexport default function stripAnsi(string) {\n\tif (typeof string !== 'string') {\n\t\tthrow new TypeError(`Expected a \\`string\\`, got \\`${typeof string}\\``);\n\t}\n\n\t// Even though the regex is global, we don't need to reset the `.lastIndex`\n\t// because unlike `.exec()` and `.test()`, `.replace()` does it automatically\n\t// and doing it manually has a performance penalty.\n\treturn string.replace(regex, '');\n}\n", "import path from 'path'\n\n/**\n * Normalize `filePath` to use forward slashes as a separator. `filePath` is\n * treated as a path specific to the current platform, so backslashes will only\n * be replaced with forward slashes on Windows. On other platforms, where a\n * backslash is a valid filename character, it will be treated as such and will\n * not be replaced.\n */\nexport function pathToPosix(filePath: string): string {\n if (path.sep === path.posix.sep) {\n return filePath\n }\n return filePath.split(path.sep).join(path.posix.sep)\n}\n\n/**\n * Returns the longest common path ancestor of the two paths (which may also be equal to one or both of them).\n * If they don't share a common ancestor (which may be the case on Windows if both paths are on different disks),\n * returns `undefined`.\n */\nexport function longestCommonPathPrefix(pathA: string, pathB: string): string | undefined {\n if (!path.isAbsolute(pathA) || !path.isAbsolute(pathB)) {\n throw new Error('longestCommonPathPrefix expects absolute paths')\n }\n\n if (process.platform === 'win32' && (pathA.startsWith('\\\\\\\\') || pathB.startsWith('\\\\\\\\'))) {\n // Make both paths namespaced if at least one of them is.\n pathA = path.toNamespacedPath(pathA)\n pathB = path.toNamespacedPath(pathB)\n }\n\n const commonPrefix = longestCommonPrefix(pathA.split(path.sep), pathB.split(path.sep)).join(path.sep)\n\n if (commonPrefix === '') {\n return process.platform === 'win32' ? undefined : '/'\n }\n\n if (process.platform === 'win32' && ['\\\\', '\\\\\\\\?', '\\\\\\\\.'].includes(commonPrefix)) {\n return undefined\n }\n\n if (process.platform === 'win32' && commonPrefix.endsWith(':')) {\n // Disk specifier without a backslash at the end is not an absolute path on windows,\n // it refers to current working directory on that disk.\n return commonPrefix + '\\\\'\n }\n\n return commonPrefix\n}\n\nfunction longestCommonPrefix<T>(sequenceA: T[], sequenceB: T[]): T[] {\n const maxLen = Math.min(sequenceA.length, sequenceB.length)\n let sliceLen = 0\n\n while (sliceLen <= maxLen && sequenceA[sliceLen] === sequenceB[sliceLen]) {\n sliceLen++\n }\n\n return sequenceA.slice(0, sliceLen)\n}\n", "export function hasOwnProperty(object: object, key: PropertyKey): boolean {\n return Object.prototype.hasOwnProperty.call(object, key)\n}\n", "export function mapObjectValues<K extends PropertyKey, T, U>(\n object: Record<K, T>,\n mapper: (value: T, key: K) => U,\n): Record<K, U> {\n const result = {} as Record<K, U>\n\n for (const key of Object.keys(object)) {\n result[key] = mapper(object[key] as T, key as K)\n }\n\n return result\n}\n", "/**\n * Accepts an array and comparator function (similar to Array.prototype.sort)\n * and returns max element of that array, ordered with that comparator.\n * Functionally, equivalent of items.sort(comparator).at(-1), but performed non-destructively\n * in O(n)\n * @param items\n * @param comparator callback specifying the relative order of two items. See `Array.prototype.sort`\n * @returns\n */\nexport function maxWithComparator<T>(items: T[], comparator: (a: T, b: T) => number): T | undefined {\n if (items.length === 0) {\n return undefined\n }\n let result = items[0]\n\n for (let i = 1; i < items.length; i++) {\n const compareValue = comparator(result, items[i])\n // comparator returning negative number means that b>a\n if (compareValue < 0) {\n result = items[i]\n }\n }\n return result\n}\n\nexport function maxBy<T>(items: T[], callback: (item: T) => number): T | undefined {\n return maxWithComparator(items, (a, b) => callback(a) - callback(b))\n}\n", "/**\n * Used for preserving class names for minified class instances\n * Useful for error objects and other classes where public name\n * actually matters\n *\n * @param classObject\n * @param name\n */\nexport function setClassName(classObject: Function, name: string) {\n Object.defineProperty(classObject, 'name', {\n value: name,\n configurable: true,\n })\n}\n", "import { warn } from './logger'\n\nconst alreadyWarned = new Set()\n\nexport const warnOnce = (key: string, message: string, ...args: unknown[]) => {\n if (!alreadyWarned.has(key)) {\n alreadyWarned.add(key)\n warn(message, ...args)\n }\n}\n", "export function isDate(value: unknown): value is Date {\n return (\n value instanceof Date ||\n // date created in other JS context (for example, worker)\n Object.prototype.toString.call(value) === '[object Date]'\n )\n}\n\nexport function isValidDate(date: Date) {\n return date.toString() !== 'Invalid Date'\n}\n", "import { Decimal } from '@prisma/client-runtime-utils'\n\nimport { DecimalJsLike } from '../core/types/exported/DecimalJsLike'\n\nexport function isDecimalJsLike(value: unknown): value is DecimalJsLike {\n if (Decimal.isDecimal(value)) {\n return true\n }\n return (\n value !== null &&\n typeof value === 'object' &&\n typeof value['s'] === 'number' &&\n typeof value['e'] === 'number' &&\n typeof value['toFixed'] === 'function' &&\n Array.isArray(value['d'])\n )\n}\n", "import { PrismaClientValidationError } from '@prisma/client-runtime-utils'\n\nimport { ErrorFormat } from '../../getPrismaClient'\nimport { CallSite } from '../../utils/CallSite'\nimport { createErrorMessageWithContext } from '../../utils/createErrorMessageWithContext'\nimport { GlobalOmitOptions } from '../jsonProtocol/serializeJsonQuery'\nimport { JsArgs } from '../types/exported/JsApi'\nimport { ValidationError } from '../types/ValidationError'\nimport { applyValidationError } from './applyValidationError'\nimport { buildArgumentsRenderingTree, renderArgsTree } from './ArgumentsRenderingTree'\n\ntype ExceptionParams = {\n errors: ValidationError[]\n args: JsArgs\n callsite?: CallSite\n originalMethod: string\n errorFormat: ErrorFormat\n clientVersion: string\n globalOmit?: GlobalOmitOptions\n}\n\nexport function throwValidationException({\n args,\n errors,\n errorFormat,\n callsite,\n originalMethod,\n clientVersion,\n globalOmit,\n}: ExceptionParams): never {\n const argsTree = buildArgumentsRenderingTree(args)\n for (const error of errors) {\n applyValidationError(error, argsTree, globalOmit)\n }\n\n const { message, args: renderedArgs } = renderArgsTree(argsTree, errorFormat)\n\n const messageWithContext = createErrorMessageWithContext({\n message,\n callsite,\n originalMethod,\n showColors: errorFormat === 'pretty',\n callArguments: renderedArgs,\n })\n\n throw new PrismaClientValidationError(messageWithContext, { clientVersion })\n}\n", "export * from './convert'\nexport * from './dmmf'\nexport * from './util'\n", "import { DatamodelEnum, SchemaEnum } from './dmmf'\n\nexport function datamodelEnumToSchemaEnum(datamodelEnum: DatamodelEnum): SchemaEnum {\n return {\n name: datamodelEnum.name,\n values: datamodelEnum.values.map((v) => v.name),\n }\n}\n", "import { ReadonlyDeep } from './util'\n\nexport type Document = ReadonlyDeep<{\n datamodel: Datamodel\n schema: Schema\n mappings: Mappings\n}>\n\nexport type Mappings = ReadonlyDeep<{\n modelOperations: ModelMapping[]\n otherOperations: {\n read: string[]\n write: string[]\n }\n}>\n\nexport type OtherOperationMappings = ReadonlyDeep<{\n read: string[]\n write: string[]\n}>\n\nexport type DatamodelEnum = ReadonlyDeep<{\n name: string\n values: EnumValue[]\n dbName?: string | null\n documentation?: string\n}>\n\nexport type SchemaEnum = ReadonlyDeep<{\n name: string\n values: string[]\n}>\n\nexport type EnumValue = ReadonlyDeep<{\n name: string\n dbName: string | null\n}>\n\nexport type Datamodel = ReadonlyDeep<{\n models: Model[]\n enums: DatamodelEnum[]\n types: Model[]\n indexes: Index[]\n}>\n\nexport type uniqueIndex = ReadonlyDeep<{\n name: string\n fields: string[]\n}>\nexport type PrimaryKey = ReadonlyDeep<{\n name: string | null\n fields: string[]\n}>\nexport type Model = ReadonlyDeep<{\n name: string\n dbName: string | null\n schema: string | null\n fields: Field[]\n uniqueFields: string[][]\n uniqueIndexes: uniqueIndex[]\n documentation?: string\n primaryKey: PrimaryKey | null\n isGenerated?: boolean\n}>\n\nexport type FieldKind = 'scalar' | 'object' | 'enum' | 'unsupported'\n\nexport type FieldNamespace = 'model' | 'prisma'\nexport type FieldLocation = 'scalar' | 'inputObjectTypes' | 'outputObjectTypes' | 'enumTypes' | 'fieldRefTypes'\n\nexport type Field = ReadonlyDeep<{\n kind: FieldKind\n name: string\n isRequired: boolean\n isList: boolean\n isUnique: boolean\n isId: boolean\n isReadOnly: boolean\n isGenerated?: boolean // does not exist on 'type' but does on 'model'\n isUpdatedAt?: boolean // does not exist on 'type' but does on 'model'\n /**\n * Describes the data type in the same the way it is defined in the Prisma schema:\n * BigInt, Boolean, Bytes, DateTime, Decimal, Float, Int, JSON, String, $ModelName\n */\n type: string\n /**\n * Native database type, if specified.\n * For example, `@db.VarChar(191)` is encoded as `['VarChar', ['191']]`,\n * `@db.Text` is encoded as `['Text', []]`.\n */\n nativeType?: [string, string[]] | null\n dbName?: string | null\n hasDefaultValue: boolean\n default?: FieldDefault | FieldDefaultScalar | FieldDefaultScalar[]\n relationFromFields?: string[]\n relationToFields?: string[]\n relationOnDelete?: string\n relationOnUpdate?: string\n relationName?: string\n documentation?: string\n}>\n\nexport type FieldDefault = ReadonlyDeep<{\n name: string\n args: Array<string | number>\n}>\n\nexport type FieldDefaultScalar = string | boolean | number\n\nexport type Index = ReadonlyDeep<{\n model: string\n type: IndexType\n isDefinedOnField: boolean\n name?: string\n dbName?: string\n algorithm?: string\n clustered?: boolean\n fields: IndexField[]\n}>\n\nexport type IndexType = 'id' | 'normal' | 'unique' | 'fulltext'\n\nexport type IndexField = ReadonlyDeep<{\n name: string\n sortOrder?: SortOrder\n length?: number\n operatorClass?: string\n}>\n\nexport type SortOrder = 'asc' | 'desc'\n\nexport type Schema = ReadonlyDeep<{\n rootQueryType?: string\n rootMutationType?: string\n inputObjectTypes: {\n // For now there are no `model` InputTypes\n model?: InputType[]\n prisma?: InputType[]\n }\n outputObjectTypes: {\n model: OutputType[]\n prisma: OutputType[]\n }\n enumTypes: {\n model?: SchemaEnum[]\n prisma: SchemaEnum[]\n }\n fieldRefTypes: {\n prisma?: FieldRefType[]\n }\n}>\n\nexport type Query = ReadonlyDeep<{\n name: string\n args: SchemaArg[]\n output: QueryOutput\n}>\n\nexport type QueryOutput = ReadonlyDeep<{\n name: string\n isRequired: boolean\n isList: boolean\n}>\n\nexport type TypeRef<AllowedLocations extends FieldLocation> = {\n isList: boolean\n type: string\n location: AllowedLocations\n namespace?: FieldNamespace\n}\n\nexport type InputTypeRef = TypeRef<'scalar' | 'inputObjectTypes' | 'enumTypes' | 'fieldRefTypes'>\n\nexport type SchemaArg = ReadonlyDeep<{\n name: string\n comment?: string\n isNullable: boolean\n isRequired: boolean\n inputTypes: InputTypeRef[]\n isParameterizable: boolean\n requiresOtherFields?: string[]\n deprecation?: Deprecation\n}>\n\nexport type OutputType = ReadonlyDeep<{\n name: string\n fields: SchemaField[]\n}>\n\nexport type SchemaField = ReadonlyDeep<{\n name: string\n isNullable?: boolean\n outputType: OutputTypeRef\n args: SchemaArg[]\n deprecation?: Deprecation\n documentation?: string\n}>\n\nexport type OutputTypeRef = TypeRef<'scalar' | 'outputObjectTypes' | 'enumTypes'>\n\nexport type Deprecation = ReadonlyDeep<{\n sinceVersion: string\n reason: string\n plannedRemovalVersion?: string\n}>\n\nexport type InputType = ReadonlyDeep<{\n name: string\n constraints: {\n maxNumFields: number | null\n minNumFields: number | null\n fields?: string[]\n }\n meta?: {\n source?: string\n grouping?: string\n }\n fields: SchemaArg[]\n}>\n\nexport type FieldRefType = ReadonlyDeep<{\n name: string\n allowTypes: FieldRefAllowType[]\n fields: SchemaArg[]\n}>\n\nexport type FieldRefAllowType = TypeRef<'scalar' | 'enumTypes'>\n\nexport type ModelMapping = ReadonlyDeep<{\n model: string\n plural: string\n findUnique?: string | null\n findUniqueOrThrow?: string | null\n findFirst?: string | null\n findFirstOrThrow?: string | null\n findMany?: string | null\n create?: string | null\n createMany?: string | null\n createManyAndReturn?: string | null\n update?: string | null\n updateMany?: string | null\n updateManyAndReturn?: string | null\n upsert?: string | null\n delete?: string | null\n deleteMany?: string | null\n aggregate?: string | null\n groupBy?: string | null\n count?: string | null\n findRaw?: string | null\n aggregateRaw?: string | null\n}>\n\nexport enum ModelAction {\n findUnique = 'findUnique',\n findUniqueOrThrow = 'findUniqueOrThrow',\n findFirst = 'findFirst',\n findFirstOrThrow = 'findFirstOrThrow',\n findMany = 'findMany',\n create = 'create',\n createMany = 'createMany',\n createManyAndReturn = 'createManyAndReturn',\n update = 'update',\n updateMany = 'updateMany',\n updateManyAndReturn = 'updateManyAndReturn',\n upsert = 'upsert',\n delete = 'delete',\n deleteMany = 'deleteMany',\n groupBy = 'groupBy',\n count = 'count', // TODO: count does not actually exist in DMMF\n aggregate = 'aggregate',\n findRaw = 'findRaw',\n aggregateRaw = 'aggregateRaw',\n}\n", "import * as DMMF from '@prisma/dmmf'\nimport indentString from 'indent-string'\nimport { bold, dim, gray, red, underline } from 'kleur/colors'\n\nimport { CallSite, LocationInFile } from './CallSite'\nimport { SourceFileSlice } from './SourceFileSlice'\n\ndeclare global {\n /**\n * a global variable that is injected by us via jest to make our snapshots\n * work in clients that cannot read from disk (e.g. wasm or edge clients)\n */\n let $getTemplateParameters: typeof getTemplateParameters | undefined\n}\n\nexport interface ErrorArgs {\n callsite?: CallSite\n originalMethod: string\n message: string\n isPanic?: boolean\n showColors?: boolean\n callArguments?: string\n}\n\ntype Colors = {\n red: (str: string) => string\n gray: (str: string) => string\n dim: (str: string) => string\n bold: (str: string) => string\n underline: (str: string) => string\n highlightSource: (source: SourceFileSlice) => SourceFileSlice\n}\n\nconst colorsEnabled: Colors = {\n red,\n gray,\n dim,\n bold,\n underline,\n highlightSource: (source) => source.highlight(),\n}\n\nconst colorsDisabled: Colors = {\n red: (str) => str,\n gray: (str) => str,\n dim: (str) => str,\n bold: (str) => str,\n underline: (str) => str,\n highlightSource: (source) => source,\n}\n\ntype ErrorContextTemplateParameters = {\n functionName: string\n message: string\n location?: LocationInFile\n contextLines?: SourceFileSlice\n callArguments?: string\n isPanic: boolean\n}\n\nfunction getRawTemplateParameters({\n message,\n originalMethod,\n isPanic,\n callArguments,\n}: ErrorArgs): ErrorContextTemplateParameters {\n return {\n functionName: `prisma.${originalMethod}()`,\n message,\n isPanic: isPanic ?? false,\n callArguments,\n }\n}\n\nexport function getTemplateParameters(\n { callsite, message, originalMethod, isPanic, callArguments }: ErrorArgs,\n colors: Colors,\n): ErrorContextTemplateParameters {\n const templateParameters = getRawTemplateParameters({ message, originalMethod, isPanic, callArguments })\n\n // @ts-ignore\n if (!callsite || typeof window !== 'undefined') {\n return templateParameters\n }\n\n if (process.env.NODE_ENV === 'production') {\n return templateParameters\n }\n\n const callLocation = callsite.getLocation()\n if (!callLocation || !callLocation.lineNumber || !callLocation.columnNumber) {\n return templateParameters\n }\n\n const contextFirstLine = Math.max(1, callLocation.lineNumber - 3)\n let source = SourceFileSlice.read(callLocation.fileName)?.slice(contextFirstLine, callLocation.lineNumber)\n const invocationLine = source?.lineAt(callLocation.lineNumber)\n if (source && invocationLine) {\n const invocationLineIndent = getIndent(invocationLine)\n const invocationCallCode = findPrismaActionCall(invocationLine)\n if (!invocationCallCode) {\n return templateParameters\n }\n templateParameters.functionName = `${invocationCallCode.code})`\n templateParameters.location = callLocation\n\n if (!isPanic) {\n source = source.mapLineAt(callLocation.lineNumber, (line) => line.slice(0, invocationCallCode.openingBraceIndex))\n }\n\n source = colors.highlightSource(source)\n const numberColumnWidth = String(source.lastLineNumber).length\n templateParameters.contextLines = source\n .mapLines((line, lineNumber) => colors.gray(String(lineNumber).padStart(numberColumnWidth)) + ' ' + line)\n .mapLines((line) => colors.dim(line))\n .prependSymbolAt(callLocation.lineNumber, colors.bold(colors.red('\u2192')))\n\n if (callArguments) {\n let indentValue = invocationLineIndent + numberColumnWidth + 1 /* space between number and code */\n indentValue += 2 // arrow + space between arrow and number\n\n // indent all lines but first, because first line of the arguments will be printed\n // on the same line as the function call\n templateParameters.callArguments = indentString(callArguments, indentValue).slice(indentValue)\n }\n }\n return templateParameters\n}\n\nfunction findPrismaActionCall(str: string): { code: string; openingBraceIndex: number } | null {\n const allActions = Object.keys(DMMF.ModelAction).join('|')\n const regexp = new RegExp(String.raw`\\.(${allActions})\\(`)\n const match = regexp.exec(str)\n if (match) {\n const openingBraceIndex = match.index + match[0].length\n // to get the code we are slicing the string up to a found brace. We start\n // with first non-space character if space is found in the line before that or\n // 0 if it is not.\n const statementStart = str.lastIndexOf(' ', match.index) + 1\n return {\n code: str.slice(statementStart, openingBraceIndex),\n openingBraceIndex,\n }\n }\n return null\n}\n\nfunction getIndent(line: string): number {\n let spaceCount = 0\n for (let i = 0; i < line.length; i++) {\n if (line.charAt(i) !== ' ') {\n return spaceCount\n }\n spaceCount++\n }\n\n return spaceCount\n}\n\nfunction stringifyErrorMessage(\n { functionName, location, message, isPanic, contextLines, callArguments }: ErrorContextTemplateParameters,\n colors: Colors,\n) {\n const lines: string[] = ['']\n\n const introSuffix = location ? ' in' : ':'\n if (isPanic) {\n lines.push(colors.red(`Oops, an unknown error occurred! This is ${colors.bold('on us')}, you did nothing wrong.`))\n lines.push(colors.red(`It occurred in the ${colors.bold(`\\`${functionName}\\``)} invocation${introSuffix}`))\n } else {\n lines.push(colors.red(`Invalid ${colors.bold(`\\`${functionName}\\``)} invocation${introSuffix}`))\n }\n\n if (location) {\n lines.push(colors.underline(stringifyLocationInFile(location)))\n }\n\n if (contextLines) {\n lines.push('')\n\n const contextLineParts = [contextLines.toString()]\n\n if (callArguments) {\n contextLineParts.push(callArguments)\n contextLineParts.push(colors.dim(')'))\n }\n lines.push(contextLineParts.join(''))\n if (callArguments) {\n lines.push('')\n }\n } else {\n lines.push('')\n if (callArguments) {\n lines.push(callArguments)\n }\n lines.push('')\n }\n\n lines.push(message)\n return lines.join('\\n')\n}\n\nfunction stringifyLocationInFile(location: LocationInFile): string {\n const parts = [location.fileName]\n if (location.lineNumber) {\n parts.push(String(location.lineNumber))\n }\n\n if (location.columnNumber) {\n parts.push(String(location.columnNumber))\n }\n\n return parts.join(':')\n}\n\nexport function createErrorMessageWithContext(args: ErrorArgs): string {\n const colors = args.showColors ? colorsEnabled : colorsDisabled\n let templateParameters: ErrorContextTemplateParameters\n\n if (TARGET_BUILD_TYPE === 'wasm-compiler-edge') {\n if (typeof $getTemplateParameters !== 'undefined') {\n templateParameters = $getTemplateParameters(args, colors)\n } else {\n templateParameters = getRawTemplateParameters(args)\n }\n } else {\n templateParameters = getTemplateParameters(args, colors)\n }\n\n return stringifyErrorMessage(templateParameters, colors)\n}\n", "import fs from 'fs'\n\nimport { highlightTS } from '../highlight/highlight'\nimport { dedent } from './dedent'\n\n/**\n * Class represents a source code or it's slice.\n * Provides various methods for manipulating individual lines\n * of the files using original files line numbers, even if the file was\n * sliced\n */\nexport class SourceFileSlice {\n /**\n * First line, stored in the slice\n */\n readonly firstLineNumber: number\n private lines: string[]\n\n static read(filePath: string): SourceFileSlice | null {\n let content: string\n try {\n content = fs.readFileSync(filePath, 'utf-8')\n } catch (e) {\n return null\n }\n\n return SourceFileSlice.fromContent(content)\n }\n\n static fromContent(content: string): SourceFileSlice {\n const lines = content.split(/\\r?\\n/)\n\n return new SourceFileSlice(1, lines)\n }\n\n private constructor(firstLine: number, lines: string[]) {\n this.firstLineNumber = firstLine\n this.lines = lines\n }\n\n /**\n * First line, stored in the slice\n */\n get lastLineNumber(): number {\n return this.firstLineNumber + this.lines.length - 1\n }\n\n /**\n * Returns new `SourceFileLines` object, where specified\n * `lineNumber` is transformed, using provided `mapFn`\n * @param lineNumber\n * @param mapFn\n * @returns\n */\n mapLineAt(lineNumber: number, mapFn: (line: string) => string): SourceFileSlice {\n if (lineNumber < this.firstLineNumber || lineNumber > this.lines.length + this.firstLineNumber) {\n return this\n }\n const idx = lineNumber - this.firstLineNumber\n const newLines = [...this.lines]\n newLines[idx] = mapFn(newLines[idx])\n return new SourceFileSlice(this.firstLineNumber, newLines)\n }\n\n /**\n * Returns new `SourceFileLines` object, where each line is transformed\n * with provided `mapFn` callback. Callback receives content of the line and\n * original line number\n * @param mapFn\n * @returns\n */\n mapLines(mapFn: (line: string, lineNumber: number) => string): SourceFileSlice {\n return new SourceFileSlice(\n this.firstLineNumber,\n this.lines.map((line, i) => mapFn(line, this.firstLineNumber + i)),\n )\n }\n\n /**\n * Returns contents of the specified line\n * @param lineNumber\n * @returns\n */\n lineAt(lineNumber: number): string | undefined {\n return this.lines[lineNumber - this.firstLineNumber]\n }\n\n /**\n * Prepends a character to the specified line and adds padding\n * to all the other lines so that they'll align\n * @param atLine\n * @param str\n * @returns\n */\n prependSymbolAt(atLine: number, str: string): SourceFileSlice {\n return this.mapLines((line, lineNumber) => {\n if (lineNumber === atLine) {\n return `${str} ${line}`\n }\n return ` ${line}`\n })\n }\n\n /**\n * Creates a new slice from a subset of specified lines of the new code\n * Lines of a slice can still be manipulated using their number in original file\n *\n * @example\n * ```ts\n * const slice = source.slice(80, 100)\n * slice.lineAt(80) === source.lineAt(80)\n * ```\n *\n * @param fromLine\n * @param toLine\n * @returns\n */\n slice(fromLine: number, toLine: number): SourceFileSlice {\n const slicedLines = this.lines.slice(fromLine - 1, toLine).join('\\n')\n return new SourceFileSlice(fromLine, dedent(slicedLines).split('\\n'))\n }\n\n /**\n * Returns new `SourceFileLines` object, where code inside of it have been\n * highlighted as typescript\n * @returns\n */\n highlight(): SourceFileSlice {\n const highlighted = highlightTS(this.toString())\n return new SourceFileSlice(this.firstLineNumber, highlighted.split('\\n'))\n }\n\n toString(): string {\n return this.lines.join('\\n')\n }\n}\n", "import { blue, bold, cyan, gray, green, yellow } from 'kleur/colors'\n\nimport type { Theme } from './types'\n\nexport const theme: Theme = {\n keyword: cyan,\n entity: cyan,\n value: (s) => bold(blue(s)),\n punctuation: blue,\n directive: cyan,\n function: cyan,\n variable: (s) => bold(blue(s)),\n string: (s) => bold(green(s)),\n boolean: yellow,\n number: cyan,\n comment: gray,\n}\n", "import { theme } from './theme'\n\nconst identity = (str: string) => str\n\n/* eslint-disable */\n\n/* **********************************************\n Begin prism-core.js\n********************************************** */\n\nconst _self: any = {}\n\n/**\n * Prism: Lightweight, robust, elegant syntax highlighting\n * MIT license http://www.opensource.org/licenses/mit-license.php/\n * @author Lea Verou http://lea.verou.me\n */\n\n// Private helper vars\nlet uniqueId = 0\n\nexport var Prism: any = {\n manual: _self.Prism && _self.Prism.manual,\n disableWorkerMessageHandler: _self.Prism && _self.Prism.disableWorkerMessageHandler,\n util: {\n encode: function (tokens: any) {\n if (tokens instanceof Token) {\n const anyTokens: any = tokens\n return new Token(anyTokens.type, Prism.util.encode(anyTokens.content), anyTokens.alias)\n } else if (Array.isArray(tokens)) {\n return tokens.map(Prism.util.encode)\n } else {\n return tokens\n .replace(/&/g, '&')\n .replace(/</g, '<')\n .replace(/\\u00a0/g, ' ')\n }\n },\n\n type: function (o) {\n return Object.prototype.toString.call(o).slice(8, -1)\n },\n\n objId: function (obj) {\n if (!obj['__id']) {\n Object.defineProperty(obj, '__id', { value: ++uniqueId })\n }\n return obj['__id']\n },\n\n // Deep clone a language definition (e.g. to extend it)\n clone: function deepClone(o, visited?: any) {\n let clone,\n id,\n type = Prism.util.type(o)\n visited = visited || {}\n\n switch (type) {\n case 'Object':\n id = Prism.util.objId(o)\n if (visited[id]) {\n return visited[id]\n }\n clone = {}\n visited[id] = clone\n\n for (const key in o) {\n if (o.hasOwnProperty(key)) {\n clone[key] = deepClone(o[key], visited)\n }\n }\n\n return clone\n\n case 'Array':\n id = Prism.util.objId(o)\n if (visited[id]) {\n return visited[id]\n }\n clone = []\n visited[id] = clone\n\n o.forEach(function (v, i) {\n clone[i] = deepClone(v, visited)\n })\n\n return clone\n\n default:\n return o\n }\n },\n },\n\n languages: {\n extend: function (id, redef) {\n const lang = Prism.util.clone(Prism.languages[id])\n\n for (const key in redef) {\n lang[key] = redef[key]\n }\n\n return lang\n },\n\n /**\n * Insert a token before another token in a language literal\n * As this needs to recreate the object (we cannot actually insert before keys in object literals),\n * we cannot just provide an object, we need an object and a key.\n * @param inside The key (or language id) of the parent\n * @param before The key to insert before.\n * @param insert Object with the key/value pairs to insert\n * @param root The object that contains `inside`. If equal to Prism.languages, it can be omitted.\n */\n insertBefore: function (inside, before, insert, root) {\n root = root || Prism.languages\n const grammar = root[inside]\n const ret = {}\n\n for (const token in grammar) {\n if (grammar.hasOwnProperty(token)) {\n if (token == before) {\n for (const newToken in insert) {\n if (insert.hasOwnProperty(newToken)) {\n ret[newToken] = insert[newToken]\n }\n }\n }\n\n // Do not insert token which also occur in insert. See #1525\n if (!insert.hasOwnProperty(token)) {\n ret[token] = grammar[token]\n }\n }\n }\n\n const old = root[inside]\n root[inside] = ret\n\n // Update references in other language definitions\n Prism.languages.DFS(Prism.languages, function (this: any, key, value) {\n if (value === old && key != inside) {\n this[key] = ret\n }\n })\n\n return ret\n },\n\n // Traverse a language definition with Depth First Search\n DFS: function DFS(o, callback, type?: any, visited?: any) {\n visited = visited || {}\n\n const objId = Prism.util.objId\n\n for (const i in o) {\n if (o.hasOwnProperty(i)) {\n callback.call(o, i, o[i], type || i)\n\n const property = o[i],\n propertyType = Prism.util.type(property)\n\n if (propertyType === 'Object' && !visited[objId(property)]) {\n visited[objId(property)] = true\n DFS(property, callback, null, visited)\n } else if (propertyType === 'Array' && !visited[objId(property)]) {\n visited[objId(property)] = true\n DFS(property, callback, i, visited)\n }\n }\n }\n },\n },\n plugins: {},\n\n highlight: function (text, grammar, language) {\n const env: any = {\n code: text,\n grammar: grammar,\n language: language,\n }\n Prism.hooks.run('before-tokenize', env)\n env.tokens = Prism.tokenize(env.code, env.grammar)\n Prism.hooks.run('after-tokenize', env)\n return Token.stringify(Prism.util.encode(env.tokens), env.language)\n },\n\n matchGrammar: function (text, strarr, grammar, index, startPos, oneshot, target?: any) {\n for (const token in grammar) {\n if (!grammar.hasOwnProperty(token) || !grammar[token]) {\n continue\n }\n\n if (token == target) {\n return\n }\n\n let patterns = grammar[token]\n patterns = Prism.util.type(patterns) === 'Array' ? patterns : [patterns]\n\n for (let j = 0; j < patterns.length; ++j) {\n let pattern = patterns[j],\n inside = pattern.inside,\n lookbehind = !!pattern.lookbehind,\n greedy = !!pattern.greedy,\n lookbehindLength = 0,\n alias = pattern.alias\n\n if (greedy && !pattern.pattern.global) {\n // Without the global flag, lastIndex won't work\n const flags = pattern.pattern.toString().match(/[imuy]*$/)[0]\n pattern.pattern = RegExp(pattern.pattern.source, flags + 'g')\n }\n\n pattern = pattern.pattern || pattern\n\n // Don\u2019t cache length as it changes during the loop\n for (let i = index, pos = startPos; i < strarr.length; pos += strarr[i].length, ++i) {\n let str = strarr[i]\n\n if (strarr.length > text.length) {\n // Something went terribly wrong, ABORT, ABORT!\n return\n }\n\n if (str instanceof Token) {\n continue\n }\n\n if (greedy && i != strarr.length - 1) {\n pattern.lastIndex = pos\n var match = pattern.exec(text)\n if (!match) {\n break\n }\n\n var from = match.index + (lookbehind ? match[1].length : 0),\n to = match.index + match[0].length,\n k = i,\n p = pos\n\n for (let len = strarr.length; k < len && (p < to || (!strarr[k].type && !strarr[k - 1].greedy)); ++k) {\n p += strarr[k].length\n // Move the index i to the element in strarr that is closest to from\n if (from >= p) {\n ++i\n pos = p\n }\n }\n\n // If strarr[i] is a Token, then the match starts inside another Token, which is invalid\n if (strarr[i] instanceof Token) {\n continue\n }\n\n // Number of tokens to delete and replace with the new match\n delNum = k - i\n str = text.slice(pos, p)\n match.index -= pos\n } else {\n pattern.lastIndex = 0\n\n var match = pattern.exec(str),\n delNum = 1\n }\n\n if (!match) {\n if (oneshot) {\n break\n }\n\n continue\n }\n\n if (lookbehind) {\n lookbehindLength = match[1] ? match[1].length : 0\n }\n\n var from = match.index + lookbehindLength,\n match = match[0].slice(lookbehindLength),\n to = from + match.length,\n before = str.slice(0, from),\n after = str.slice(to)\n\n const args: any = [i, delNum]\n\n if (before) {\n ++i\n pos += before.length\n args.push(before)\n }\n\n const wrapped = new Token(token, inside ? Prism.tokenize(match, inside) : match, alias, match, greedy)\n\n args.push(wrapped)\n\n if (after) {\n args.push(after)\n }\n\n Array.prototype.splice.apply(strarr, args)\n\n if (delNum != 1) Prism.matchGrammar(text, strarr, grammar, i, pos, true, token)\n\n if (oneshot) break\n }\n }\n }\n },\n\n tokenize: function (text, grammar) {\n const strarr = [text]\n\n const rest = grammar.rest\n\n if (rest) {\n for (const token in rest) {\n grammar[token] = rest[token]\n }\n\n delete grammar.rest\n }\n\n Prism.matchGrammar(text, strarr, grammar, 0, 0, false)\n\n return strarr\n },\n\n hooks: {\n all: {},\n\n add: function (name, callback) {\n const hooks = Prism.hooks.all\n\n hooks[name] = hooks[name] || []\n\n hooks[name].push(callback)\n },\n\n run: function (name, env) {\n const callbacks = Prism.hooks.all[name]\n\n if (!callbacks || !callbacks.length) {\n return\n }\n\n for (var i = 0, callback; (callback = callbacks[i++]); ) {\n callback(env)\n }\n },\n },\n\n Token: Token,\n}\n\nPrism.languages.clike = {\n comment: [\n {\n pattern: /(^|[^\\\\])\\/\\*[\\s\\S]*?(?:\\*\\/|$)/,\n lookbehind: true,\n },\n {\n pattern: /(^|[^\\\\:])\\/\\/.*/,\n lookbehind: true,\n greedy: true,\n },\n ],\n string: {\n pattern: /([\"'])(?:\\\\(?:\\r\\n|[\\s\\S])|(?!\\1)[^\\\\\\r\\n])*\\1/,\n greedy: true,\n },\n 'class-name': {\n pattern: /((?:\\b(?:class|interface|extends|implements|trait|instanceof|new)\\s+)|(?:catch\\s+\\())[\\w.\\\\]+/i,\n lookbehind: true,\n inside: {\n punctuation: /[.\\\\]/,\n },\n },\n keyword: /\\b(?:if|else|while|do|for|return|in|instanceof|function|new|try|throw|catch|finally|null|break|continue)\\b/,\n boolean: /\\b(?:true|false)\\b/,\n function: /\\w+(?=\\()/,\n number: /\\b0x[\\da-f]+\\b|(?:\\b\\d+\\.?\\d*|\\B\\.\\d+)(?:e[+-]?\\d+)?/i,\n operator: /--?|\\+\\+?|!=?=?|<=?|>=?|==?=?|&&?|\\|\\|?|\\?|\\*|\\/|~|\\^|%/,\n punctuation: /[{}[\\];(),.:]/,\n}\n\nPrism.languages.javascript = Prism.languages.extend('clike', {\n 'class-name': [\n Prism.languages.clike['class-name'],\n {\n pattern: /(^|[^$\\w\\xA0-\\uFFFF])[_$A-Z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*(?=\\.(?:prototype|constructor))/,\n lookbehind: true,\n },\n ],\n keyword: [\n {\n pattern: /((?:^|})\\s*)(?:catch|finally)\\b/,\n lookbehind: true,\n },\n {\n pattern:\n /(^|[^.])\\b(?:as|async(?=\\s*(?:function\\b|\\(|[$\\w\\xA0-\\uFFFF]|$))|await|break|case|class|const|continue|debugger|default|delete|do|else|enum|export|extends|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)\\b/,\n lookbehind: true,\n },\n ],\n number:\n /\\b(?:(?:0[xX](?:[\\dA-Fa-f](?:_[\\dA-Fa-f])?)+|0[bB](?:[01](?:_[01])?)+|0[oO](?:[0-7](?:_[0-7])?)+)n?|(?:\\d(?:_\\d)?)+n|NaN|Infinity)\\b|(?:\\b(?:\\d(?:_\\d)?)+\\.?(?:\\d(?:_\\d)?)*|\\B\\.(?:\\d(?:_\\d)?)+)(?:[Ee][+-]?(?:\\d(?:_\\d)?)+)?/,\n // Allow for all non-ASCII characters (See http://stackoverflow.com/a/2008444)\n function: /[_$a-zA-Z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*(?=\\s*(?:\\.\\s*(?:apply|bind|call)\\s*)?\\()/,\n operator: /-[-=]?|\\+[+=]?|!=?=?|<<?=?|>>?>?=?|=(?:==?|>)?|&[&=]?|\\|[|=]?|\\*\\*?=?|\\/=?|~|\\^=?|%=?|\\?|\\.{3}/,\n})\n\nPrism.languages.javascript['class-name'][0].pattern =\n /(\\b(?:class|interface|extends|implements|instanceof|new)\\s+)[\\w.\\\\]+/\n\nPrism.languages.insertBefore('javascript', 'keyword', {\n regex: {\n pattern:\n /((?:^|[^$\\w\\xA0-\\uFFFF.\"'\\])\\s])\\s*)\\/(\\[(?:[^\\]\\\\\\r\\n]|\\\\.)*]|\\\\.|[^/\\\\\\[\\r\\n])+\\/[gimyus]{0,6}(?=\\s*($|[\\r\\n,.;})\\]]))/,\n lookbehind: true,\n greedy: true,\n },\n // This must be declared before keyword because we use \"function\" inside the look-forward\n 'function-variable': {\n pattern:\n /[_$a-zA-Z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*(?=\\s*[=:]\\s*(?:async\\s*)?(?:\\bfunction\\b|(?:\\((?:[^()]|\\([^()]*\\))*\\)|[_$a-zA-Z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*)\\s*=>))/,\n alias: 'function',\n },\n parameter: [\n {\n pattern: /(function(?:\\s+[_$A-Za-z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*)?\\s*\\(\\s*)(?!\\s)(?:[^()]|\\([^()]*\\))+?(?=\\s*\\))/,\n lookbehind: true,\n inside: Prism.languages.javascript,\n },\n {\n pattern: /[_$a-z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*(?=\\s*=>)/i,\n inside: Prism.languages.javascript,\n },\n {\n pattern: /(\\(\\s*)(?!\\s)(?:[^()]|\\([^()]*\\))+?(?=\\s*\\)\\s*=>)/,\n lookbehind: true,\n inside: Prism.languages.javascript,\n },\n {\n pattern:\n /((?:\\b|\\s|^)(?!(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)(?![$\\w\\xA0-\\uFFFF]))(?:[_$A-Za-z\\xA0-\\uFFFF][$\\w\\xA0-\\uFFFF]*\\s*)\\(\\s*)(?!\\s)(?:[^()]|\\([^()]*\\))+?(?=\\s*\\)\\s*\\{)/,\n lookbehind: true,\n inside: Prism.languages.javascript,\n },\n ],\n constant: /\\b[A-Z](?:[A-Z_]|\\dx?)*\\b/,\n})\n\nif (Prism.languages.markup) {\n Prism.languages.markup.tag.addInlined('script', 'javascript')\n}\n\nPrism.languages.js = Prism.languages.javascript\n\nPrism.languages.typescript = Prism.languages.extend('javascript', {\n // From JavaScript Prism keyword list and TypeScript language spec: https://github.com/Microsoft/TypeScript/blob/master/doc/spec.md#221-reserved-words\n keyword:\n /\\b(?:abstract|as|async|await|break|case|catch|class|const|constructor|continue|debugger|declare|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|is|keyof|let|module|namespace|new|null|of|package|private|protected|public|readonly|return|require|set|static|super|switch|this|throw|try|type|typeof|var|void|while|with|yield)\\b/,\n builtin: /\\b(?:string|Function|any|number|boolean|Array|symbol|console|Promise|unknown|never)\\b/,\n})\n\nPrism.languages.ts = Prism.languages.typescript\n\nexport function Token(this: any, type, content, alias, matchedStr?: any, greedy?: any) {\n this.type = type\n this.content = content\n this.alias = alias\n // Copy of the full string this token was created from\n this.length = (matchedStr || '').length | 0\n this.greedy = !!greedy\n}\n\nToken.stringify = function (o, language?: any) {\n if (typeof o == 'string') {\n return o\n }\n\n if (Array.isArray(o)) {\n return o\n .map(function (element) {\n return Token.stringify(element, language)\n })\n .join('')\n }\n\n return getColorForSyntaxKind(o.type)(o.content)\n}\n\nfunction getColorForSyntaxKind(syntaxKind: string) {\n return theme[syntaxKind] || identity\n}\n", "import { Prism, Token } from './prism'\nimport type { SyntaxDefinition } from './types'\n\nexport function highlightTS(str: string) {\n return highlight(str, Prism.languages.javascript)\n}\n\nfunction highlight(str: string, grammar: SyntaxDefinition) {\n const tokens = Prism.tokenize(str, grammar)\n return tokens.map((t) => Token.stringify(t)).join('')\n}\n", "import strip from 'strip-indent'\n\nexport function dedent(str: string): string {\n return strip(str)\n}\n", "import { uncapitalize } from '@prisma/client-common'\nimport levenshtein from 'js-levenshtein'\n\nimport {\n ArgumentDescription,\n EmptySelectionError,\n InputTypeDescription,\n InvalidArgumentTypeError,\n InvalidArgumentValueError,\n OutputTypeDescription,\n RequiredArgumentMissingError,\n SomeFieldsMissingError,\n TooManyFieldsGivenError,\n UnknownArgumentError,\n UnknownInputFieldError,\n UnknownSelectionFieldError,\n ValueTooLargeError,\n} from '../engines'\nimport { GlobalOmitOptions } from '../jsonProtocol/serializeJsonQuery'\nimport {\n IncludeOnScalarError,\n InvalidSelectionValueError,\n MutuallyExclusiveFieldsError,\n ValidationError,\n} from '../types/ValidationError'\nimport { applyUnionError } from './applyUnionError'\nimport { ArgumentsRenderingTree } from './ArgumentsRenderingTree'\nimport { Colors } from './base'\nimport { ObjectField } from './ObjectField'\nimport { ObjectFieldSuggestion } from './ObjectFieldSuggestion'\nimport { ObjectValue } from './ObjectValue'\nimport { ScalarValue } from './ScalarValue'\nimport { SuggestionObjectValue } from './SuggestionObjectValue'\n\n/**\n * Given the validation error and arguments rendering tree, applies corresponding\n * formatting to an error tree and adds all relevant messages.\n *\n * @param error\n * @param args\n */\nexport function applyValidationError(\n error: ValidationError,\n args: ArgumentsRenderingTree,\n globalOmit?: GlobalOmitOptions,\n): void {\n switch (error.kind) {\n case 'MutuallyExclusiveFields':\n applyMutuallyExclusiveFieldsError(error, args)\n break\n case 'IncludeOnScalar':\n applyIncludeOnScalarError(error, args)\n break\n case 'EmptySelection':\n applyEmptySelectionError(error, args, globalOmit)\n break\n case 'UnknownSelectionField':\n applyUnknownSelectionFieldError(error, args)\n break\n case 'InvalidSelectionValue':\n applyInvalidSelectionValueError(error, args)\n break\n case 'UnknownArgument':\n applyUnknownArgumentError(error, args)\n break\n case 'UnknownInputField':\n applyUnknownInputFieldError(error, args)\n break\n case 'RequiredArgumentMissing':\n applyRequiredArgumentMissingError(error, args)\n break\n case 'InvalidArgumentType':\n applyInvalidArgumentTypeError(error, args)\n break\n case 'InvalidArgumentValue':\n applyInvalidArgumentValueError(error, args)\n break\n case 'ValueTooLarge':\n applyValueTooLargeError(error, args)\n break\n case 'SomeFieldsMissing':\n applySomeFieldsMissingError(error, args)\n break\n case 'TooManyFieldsGiven':\n applyTooManyFieldsGivenError(error, args)\n break\n case 'Union':\n applyUnionError(error, args, globalOmit)\n break\n default:\n throw new Error('not implemented: ' + error.kind)\n }\n}\n\nfunction applyMutuallyExclusiveFieldsError(error: MutuallyExclusiveFieldsError, argsTree: ArgumentsRenderingTree) {\n const object = argsTree.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n if (object) {\n object.getField(error.firstField)?.markAsError()\n object.getField(error.secondField)?.markAsError()\n }\n\n argsTree.addErrorMessage(\n (colors) =>\n `Please ${colors.bold('either')} use ${colors.green(`\\`${error.firstField}\\``)} or ${colors.green(\n `\\`${error.secondField}\\``,\n )}, but ${colors.red('not both')} at the same time.`,\n )\n}\n\nfunction applyIncludeOnScalarError(error: IncludeOnScalarError, argsTree: ArgumentsRenderingTree) {\n const [selectionPath, field] = splitPath(error.selectionPath)\n const outputType = error.outputType\n\n const object = argsTree.arguments.getDeepSelectionParent(selectionPath)?.value\n if (object) {\n object.getField(field)?.markAsError()\n\n if (outputType) {\n for (const field of outputType.fields) {\n if (field.isRelation) {\n object.addSuggestion(new ObjectFieldSuggestion(field.name, 'true'))\n }\n }\n }\n }\n\n argsTree.addErrorMessage((colors) => {\n let msg = `Invalid scalar field ${colors.red(`\\`${field}\\``)} for ${colors.bold('include')} statement`\n if (outputType) {\n msg += ` on model ${colors.bold(outputType.name)}. ${availableOptionsMessage(colors)}`\n } else {\n msg += '.'\n }\n\n msg += `\\nNote that ${colors.bold('include')} statements only accept relation fields.`\n return msg\n })\n}\n\nfunction applyEmptySelectionError(\n error: EmptySelectionError,\n argsTree: ArgumentsRenderingTree,\n globalOmit?: GlobalOmitOptions,\n) {\n const subSelection = argsTree.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n if (subSelection) {\n const omit = subSelection.getField('omit')?.value.asObject()\n if (omit) {\n applyEmptySelectionErrorOmit(error, argsTree, omit)\n return\n }\n if (subSelection.hasField('select')) {\n applyEmptySelectionErrorSelect(error, argsTree)\n return\n }\n }\n\n if (globalOmit?.[uncapitalize(error.outputType.name)]) {\n applyEmptySelectionErrorGlobalOmit(error, argsTree)\n return\n }\n\n // should never happen, but in case it does\n argsTree.addErrorMessage(() => `Unknown field at \"${error.selectionPath.join('.')} selection\"`)\n}\n\n// case for `EmptySelectionError`, triggered by excessive omit\nfunction applyEmptySelectionErrorOmit(\n error: EmptySelectionError,\n argsTree: ArgumentsRenderingTree,\n omitValue: ObjectValue,\n) {\n omitValue.removeAllFields()\n for (const field of error.outputType.fields) {\n omitValue.addSuggestion(new ObjectFieldSuggestion(field.name, 'false'))\n }\n\n argsTree.addErrorMessage((colors) => {\n return `The ${colors.red('omit')} statement includes every field of the model ${colors.bold(\n error.outputType.name,\n )}. At least one field must be included in the result`\n })\n}\n\n// case for `EmptySelectionError`, triggered by empty/falsy `select`\nfunction applyEmptySelectionErrorSelect(error: EmptySelectionError, argsTree: ArgumentsRenderingTree) {\n const outputType = error.outputType\n const selection = argsTree.arguments.getDeepSelectionParent(error.selectionPath)?.value\n const isEmpty = selection?.isEmpty() ?? false\n\n if (selection) {\n // If selection has fields and we get EmptySelection error, it means all fields within the\n // selection are false. We have 2 possible ways to handle suggestions here:\n //\n // 1. Suggest only the fields, not present inside of the selection. Example:\n //\n // {\n // select: {\n // id: false\n // posts: false,\n // ? name?: true\n // ? email?: true\n // }\n // }\n // There are couple of possible problems here. First, we are assuming that user needs to\n // add new field to the selection, rather than change one of the existing ones to true.\n // Second, we might end up in a situation where all fields are already used in selection and we have nothing left to suggest.\n //\n // 2.Completely ignore users input and suggest all the fields. Example rendering:\n // {\n // select: {\n // ? id?: true\n // ? posts?: true,\n // ? name?: true\n // ? email?: true\n // }\n // }\n //\n // So we will be suggesting to either change one of the fields to true, or add a new one which would be true.\n // This is the approach we are taking and in order to it, we need to remove all the fields from selection. Code\n // below will then add them back as a suggestion.\n selection.removeAllFields()\n addSelectionSuggestions(selection, outputType)\n }\n\n argsTree.addErrorMessage((colors) => {\n if (isEmpty) {\n return `The ${colors.red('`select`')} statement for type ${colors.bold(\n outputType.name,\n )} must not be empty. ${availableOptionsMessage(colors)}`\n }\n return `The ${colors.red('`select`')} statement for type ${colors.bold(outputType.name)} needs ${colors.bold(\n 'at least one truthy value',\n )}.`\n })\n}\n\n// case for `EmptySelectionError`, triggered by excessive global omit\nfunction applyEmptySelectionErrorGlobalOmit(error: EmptySelectionError, argsTree: ArgumentsRenderingTree) {\n const suggestedOmitConfig = new SuggestionObjectValue()\n for (const field of error.outputType.fields) {\n if (!field.isRelation) {\n suggestedOmitConfig.addField(field.name, 'false')\n }\n }\n\n const omitSuggestion = new ObjectFieldSuggestion('omit', suggestedOmitConfig).makeRequired()\n\n if (error.selectionPath.length === 0) {\n argsTree.arguments.addSuggestion(omitSuggestion)\n } else {\n const [parentPath, fieldName] = splitPath(error.selectionPath)\n const parent = argsTree.arguments.getDeepSelectionParent(parentPath)?.value.asObject()\n const field = parent?.getField(fieldName)\n if (field) {\n const fieldValue = field?.value.asObject() ?? new ObjectValue()\n fieldValue.addSuggestion(omitSuggestion)\n field.value = fieldValue\n }\n }\n\n // neither select, nor omit are used, but global omit global omit configuration for the model exists\n argsTree.addErrorMessage((colors) => {\n return `The global ${colors.red('omit')} configuration excludes every field of the model ${colors.bold(\n error.outputType.name,\n )}. At least one field must be included in the result`\n })\n}\n\nfunction applyUnknownSelectionFieldError(error: UnknownSelectionFieldError, argsTree: ArgumentsRenderingTree) {\n const locateResult = locateSelectionField(error.selectionPath, argsTree)\n if (locateResult.parentKind !== 'unknown') {\n locateResult.field.markAsError()\n const parent = locateResult.parent\n switch (locateResult.parentKind) {\n case 'select':\n addSelectionSuggestions(parent, error.outputType)\n break\n case 'include':\n addInclusionSuggestions(parent, error.outputType)\n break\n case 'omit':\n addOmissionSuggestions(parent, error.outputType)\n break\n }\n }\n argsTree.addErrorMessage((colors) => {\n const parts = [`Unknown field ${colors.red(`\\`${locateResult.fieldName}\\``)}`]\n if (locateResult.parentKind !== 'unknown') {\n parts.push(`for ${colors.bold(locateResult.parentKind)} statement`)\n }\n parts.push(`on model ${colors.bold(`\\`${error.outputType.name}\\``)}.`)\n parts.push(availableOptionsMessage(colors))\n return parts.join(' ')\n })\n}\n\nfunction applyInvalidSelectionValueError(error: InvalidSelectionValueError, argsTree: ArgumentsRenderingTree) {\n const locateResult = locateSelectionField(error.selectionPath, argsTree)\n if (locateResult.parentKind !== 'unknown') {\n locateResult.field.value.markAsError()\n }\n\n argsTree.addErrorMessage((colors) => {\n return `Invalid value for selection field \\`${colors.red(locateResult.fieldName)}\\`: ${error.underlyingError}`\n })\n}\n\nfunction applyUnknownArgumentError(error: UnknownArgumentError, argsTree: ArgumentsRenderingTree) {\n const argName = error.argumentPath[0]\n const selection = argsTree.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n\n if (selection) {\n selection.getField(argName)?.markAsError()\n addArgumentsSuggestions(selection, error.arguments)\n }\n\n argsTree.addErrorMessage((colors) =>\n unknownArgumentMessage(\n colors,\n argName,\n error.arguments.map((arg) => arg.name),\n ),\n )\n}\n\nfunction applyUnknownInputFieldError(error: UnknownInputFieldError, argsTree: ArgumentsRenderingTree) {\n const [argParentPath, argName] = splitPath(error.argumentPath)\n const selection = argsTree.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n\n if (selection) {\n selection.getDeepField(error.argumentPath)?.markAsError()\n const argParent = selection.getDeepFieldValue(argParentPath)?.asObject()\n if (argParent) {\n addInputSuggestions(argParent, error.inputType)\n }\n }\n\n argsTree.addErrorMessage((colors) =>\n unknownArgumentMessage(\n colors,\n argName,\n error.inputType.fields.map((f) => f.name),\n ),\n )\n}\n\nfunction unknownArgumentMessage(colors: Colors, argName: string, options: string[]) {\n const parts = [`Unknown argument \\`${colors.red(argName)}\\`.`]\n const suggestion = getSuggestion(argName, options)\n\n if (suggestion) {\n parts.push(`Did you mean \\`${colors.green(suggestion)}\\`?`)\n }\n\n if (options.length > 0) {\n parts.push(availableOptionsMessage(colors))\n }\n\n return parts.join(' ')\n}\n\nfunction applyRequiredArgumentMissingError(error: RequiredArgumentMissingError, args: ArgumentsRenderingTree) {\n let existingField: ObjectField | undefined = undefined\n\n args.addErrorMessage((colors) => {\n if (existingField?.value instanceof ScalarValue && existingField.value.text === 'null') {\n return `Argument \\`${colors.green(argumentName)}\\` must not be ${colors.red('null')}.`\n }\n return `Argument \\`${colors.green(argumentName)}\\` is missing.`\n })\n const selection = args.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n if (!selection) {\n return\n }\n\n const [argParent, argumentName] = splitPath(error.argumentPath)\n const objectSuggestion = new SuggestionObjectValue()\n const parent = selection.getDeepFieldValue(argParent)?.asObject()\n if (!parent) {\n return\n }\n\n existingField = parent.getField(argumentName)\n if (existingField) {\n parent.removeField(argumentName)\n }\n\n if (error.inputTypes.length === 1 && error.inputTypes[0].kind === 'object') {\n for (const field of error.inputTypes[0].fields) {\n objectSuggestion.addField(field.name, field.typeNames.join(' | '))\n }\n\n parent.addSuggestion(new ObjectFieldSuggestion(argumentName, objectSuggestion).makeRequired())\n } else {\n const typeName = error.inputTypes.map(getInputTypeName).join(' | ')\n parent.addSuggestion(new ObjectFieldSuggestion(argumentName, typeName).makeRequired())\n }\n\n if (error.dependentArgumentPath) {\n selection.getDeepField(error.dependentArgumentPath)?.markAsError()\n const [, dependentArgumentName] = splitPath(error.dependentArgumentPath)\n args.addErrorMessage((colors) => {\n return `Argument \\`${colors.green(argumentName)}\\` is required because argument \\`${colors.green(\n dependentArgumentName,\n )}\\` was provided.`\n })\n }\n}\n\nfunction getInputTypeName(description: InputTypeDescription) {\n if (description.kind === 'list') {\n return `${getInputTypeName(description.elementType)}[]`\n }\n return description.name\n}\n\nfunction applyInvalidArgumentTypeError(error: InvalidArgumentTypeError, args: ArgumentsRenderingTree) {\n const argName = error.argument.name\n const selection = args.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n if (selection) {\n selection.getDeepFieldValue(error.argumentPath)?.markAsError()\n }\n\n args.addErrorMessage((colors) => {\n const expected = joinWithPreposition(\n 'or',\n error.argument.typeNames.map((type) => colors.green(type)),\n )\n // TODO: print value\n return `Argument \\`${colors.bold(argName)}\\`: Invalid value provided. Expected ${expected}, provided ${colors.red(\n error.inferredType,\n )}.`\n })\n}\n\nfunction applyInvalidArgumentValueError(error: InvalidArgumentValueError, args: ArgumentsRenderingTree) {\n const argName = error.argument.name\n const selection = args.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n if (selection) {\n selection.getDeepFieldValue(error.argumentPath)?.markAsError()\n }\n\n args.addErrorMessage((colors) => {\n const parts = [`Invalid value for argument \\`${colors.bold(argName)}\\``]\n if (error.underlyingError) {\n parts.push(`: ${error.underlyingError}`)\n }\n parts.push('.')\n if (error.argument.typeNames.length > 0) {\n const expected = joinWithPreposition(\n 'or',\n error.argument.typeNames.map((type) => colors.green(type)),\n )\n parts.push(` Expected ${expected}.`)\n }\n return parts.join('')\n })\n}\n\nfunction applyValueTooLargeError(error: ValueTooLargeError, args: ArgumentsRenderingTree) {\n const argName = error.argument.name\n const selection = args.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n let printedValue: string | undefined\n if (selection) {\n const field = selection.getDeepField(error.argumentPath)\n const value = field?.value\n value?.markAsError()\n if (value instanceof ScalarValue) {\n printedValue = value.text\n }\n }\n\n args.addErrorMessage((colors) => {\n const parts: string[] = ['Unable to fit value']\n if (printedValue) {\n parts.push(colors.red(printedValue))\n }\n parts.push(`into a 64-bit signed integer for field \\`${colors.bold(argName)}\\``)\n\n return parts.join(' ')\n })\n}\n\nfunction applySomeFieldsMissingError(error: SomeFieldsMissingError, args: ArgumentsRenderingTree) {\n const argumentName = error.argumentPath[error.argumentPath.length - 1]\n const selection = args.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n if (selection) {\n const argument = selection.getDeepFieldValue(error.argumentPath)?.asObject()\n if (argument) {\n addInputSuggestions(argument, error.inputType)\n }\n }\n\n args.addErrorMessage((colors) => {\n const parts = [`Argument \\`${colors.bold(argumentName)}\\` of type ${colors.bold(error.inputType.name)} needs`]\n if (error.constraints.minFieldCount === 1) {\n if (error.constraints.requiredFields) {\n parts.push(\n `${colors.green('at least one of')} ${joinWithPreposition(\n 'or',\n error.constraints.requiredFields.map((f) => `\\`${colors.bold(f)}\\``),\n )} arguments.`,\n )\n } else {\n parts.push(`${colors.green('at least one')} argument.`)\n }\n } else {\n parts.push(`${colors.green(`at least ${error.constraints.minFieldCount}`)} arguments.`)\n }\n parts.push(availableOptionsMessage(colors))\n return parts.join(' ')\n })\n}\n\nfunction applyTooManyFieldsGivenError(error: TooManyFieldsGivenError, args: ArgumentsRenderingTree) {\n const argumentName = error.argumentPath[error.argumentPath.length - 1]\n const selection = args.arguments.getDeepSubSelectionValue(error.selectionPath)?.asObject()\n let providedArguments: string[] = []\n if (selection) {\n const argument = selection.getDeepFieldValue(error.argumentPath)?.asObject()\n if (argument) {\n argument.markAsError()\n providedArguments = Object.keys(argument.getFields())\n }\n }\n\n args.addErrorMessage((colors) => {\n const parts = [`Argument \\`${colors.bold(argumentName)}\\` of type ${colors.bold(error.inputType.name)} needs`]\n if (error.constraints.minFieldCount === 1 && error.constraints.maxFieldCount == 1) {\n parts.push(`${colors.green('exactly one')} argument,`)\n } else if (error.constraints.maxFieldCount == 1) {\n parts.push(`${colors.green('at most one')} argument,`)\n } else {\n parts.push(`${colors.green(`at most ${error.constraints.maxFieldCount}`)} arguments,`)\n }\n\n parts.push(\n `but you provided ${joinWithPreposition(\n 'and',\n providedArguments.map((arg) => colors.red(arg)),\n )}. Please choose`,\n )\n\n if (error.constraints.maxFieldCount === 1) {\n parts.push('one.')\n } else {\n parts.push(`${error.constraints.maxFieldCount}.`)\n }\n\n return parts.join(' ')\n })\n}\n\nfunction addSelectionSuggestions(selection: ObjectValue, outputType: OutputTypeDescription) {\n for (const field of outputType.fields) {\n if (!selection.hasField(field.name)) {\n selection.addSuggestion(new ObjectFieldSuggestion(field.name, 'true'))\n }\n }\n}\n\nfunction addInclusionSuggestions(selection: ObjectValue, outputType: OutputTypeDescription) {\n for (const field of outputType.fields) {\n if (field.isRelation && !selection.hasField(field.name)) {\n selection.addSuggestion(new ObjectFieldSuggestion(field.name, 'true'))\n }\n }\n}\n\nfunction addOmissionSuggestions(selection: ObjectValue, outputType: OutputTypeDescription) {\n for (const field of outputType.fields) {\n if (!selection.hasField(field.name) && !field.isRelation) {\n selection.addSuggestion(new ObjectFieldSuggestion(field.name, 'true'))\n }\n }\n}\n\nfunction addArgumentsSuggestions(argumentsParent: ObjectValue, args: ArgumentDescription[]) {\n for (const arg of args) {\n if (!argumentsParent.hasField(arg.name)) {\n argumentsParent.addSuggestion(new ObjectFieldSuggestion(arg.name, arg.typeNames.join(' | ')))\n }\n }\n}\n\nfunction locateSelectionField(selectionPath: string[], argsTree: ArgumentsRenderingTree) {\n const [parentPath, fieldName] = splitPath(selectionPath)\n\n const subSelection = argsTree.arguments.getDeepSubSelectionValue(parentPath)?.asObject()\n if (!subSelection) {\n return { parentKind: 'unknown' as const, fieldName }\n }\n const select = subSelection.getFieldValue('select')?.asObject()\n const include = subSelection.getFieldValue('include')?.asObject()\n const omit = subSelection.getFieldValue('omit')?.asObject()\n let field = select?.getField(fieldName)\n if (select && field) {\n return { parentKind: 'select' as const, parent: select, field, fieldName }\n }\n field = include?.getField(fieldName)\n if (include && field) {\n return { parentKind: 'include' as const, field, parent: include, fieldName }\n }\n\n field = omit?.getField(fieldName)\n if (omit && field) {\n return { parentKind: 'omit' as const, field, parent: omit, fieldName }\n }\n return { parentKind: 'unknown' as const, fieldName }\n}\n\nfunction addInputSuggestions(parent: ObjectValue, inputType: InputTypeDescription) {\n if (inputType.kind !== 'object') {\n return\n }\n\n for (const field of inputType.fields) {\n if (!parent.hasField(field.name)) {\n parent.addSuggestion(new ObjectFieldSuggestion(field.name, field.typeNames.join(' | ')))\n }\n }\n}\n\nfunction splitPath(path: string[]): [parentPath: string[], fieldName: string] {\n const selectionPath = [...path]\n const fieldName = selectionPath.pop()\n if (!fieldName) {\n throw new Error('unexpected empty path')\n }\n return [selectionPath, fieldName]\n}\n\nfunction availableOptionsMessage({ green, enabled }: Colors) {\n return `Available options are ` + (enabled ? `listed in ${green('green')}` : `marked with ?`) + '.'\n}\n\nfunction joinWithPreposition(preposition: 'and' | 'or', items: string[]): string {\n if (items.length === 1) {\n return items[0]\n }\n const itemsCopy = [...items]\n const lastItem = itemsCopy.pop()\n return `${itemsCopy.join(', ')} ${preposition} ${lastItem}`\n}\n\n/**\n * Options with edit distance above this value will never be suggested\n */\nconst MAX_EDIT_DISTANCE = 3\n\nfunction getSuggestion(str: string, options: string[]): string | undefined {\n let minDistance = Infinity\n let result: string | undefined\n\n for (const option of options) {\n const editDistance = levenshtein(str, option)\n if (editDistance > MAX_EDIT_DISTANCE) {\n continue\n }\n if (editDistance < minDistance) {\n minDistance = editDistance\n result = option\n }\n }\n return result\n}\n", "import { maxWithComparator } from '@prisma/internals'\n\nimport { EngineValidationError, InvalidArgumentTypeError, UnionError } from '../engines'\nimport { GlobalOmitOptions } from '../jsonProtocol/serializeJsonQuery'\nimport { applyValidationError } from './applyValidationError'\nimport { ArgumentsRenderingTree } from './ArgumentsRenderingTree'\n\ntype NonUnionError = Exclude<EngineValidationError, UnionError>\n\n/**\n * When a particular field has multiple allowed types on the schema level\n * and none of them match users input, engine returns special kind of error: UnionError.\n * This error acts as a container for individual errors for each non-matching type.\n * In that case, we need to make a guess which of the errors corresponds users intent the most.\n * General algorithm of processing them is the following:\n * - flatten all nested errors and get a single list of all possible errors\n * - merge individual InvalidArgumentType errors at the same path\n * - pick the best error based on combined argument and selection paths length and type of the error.\n *\n * For details of each step, see other comments in this file.\n * @param error\n * @param args\n */\nexport function applyUnionError(error: UnionError, args: ArgumentsRenderingTree, globalOmit?: GlobalOmitOptions) {\n const allErrors = flattenUnionError(error)\n const merged = mergeInvalidArgumentTypeErrors(allErrors)\n const bestError = getBestScoringError(merged)\n if (bestError) {\n applyValidationError(bestError, args, globalOmit)\n } else {\n args.addErrorMessage(() => 'Unknown error')\n }\n}\n\nfunction flattenUnionError(error: UnionError): NonUnionError[] {\n return error.errors.flatMap((error) => {\n if (error.kind === 'Union') {\n return flattenUnionError(error)\n }\n return [error]\n })\n}\n\n/**\n * Iterates over provided error list and merges all InvalidArgumentType\n * with matching selectionPath and argumentPath into one. For example,\n * if the list has an error, saying that `where.arg` does not match `Int`\n * and another, saying that `where.arg` does not match IntFilter, resulting\n * list will contain a single error for `where.arg` saying it does not\n * match `Int | IntFilter`\n * @param errorList\n * @returns\n */\nfunction mergeInvalidArgumentTypeErrors(errorList: NonUnionError[]) {\n const invalidArgsError = new Map<string, InvalidArgumentTypeError>()\n const result: NonUnionError[] = []\n\n for (const error of errorList) {\n if (error.kind !== 'InvalidArgumentType') {\n result.push(error)\n continue\n }\n\n const key = `${error.selectionPath.join('.')}:${error.argumentPath.join('.')}`\n const prevError = invalidArgsError.get(key)\n if (!prevError) {\n invalidArgsError.set(key, error)\n } else {\n invalidArgsError.set(key, {\n ...error,\n argument: {\n ...error.argument,\n typeNames: uniqueConcat(prevError.argument.typeNames, error.argument.typeNames),\n },\n })\n }\n }\n\n result.push(...invalidArgsError.values())\n return result\n}\n\nfunction uniqueConcat<T>(head: T[], tail: T[]): T[] {\n return [...new Set(head.concat(tail))]\n}\n\n/**\n * Function that attempts to pick the best error from the list\n * by ranking them. In most cases, highest ranking error would be the one\n * which has the longest combined \"selectionPath\" + \"argumentPath\". Justification\n * for that is that type that made it deeper into validation tree before failing\n * is probably closer to the one user actually wanted to do.\n *\n * However, if two errors are at the same depth level, we introduce additional ranking based\n * on error type. See `getErrorTypeScore` function for details\n * @param errors\n * @returns\n */\nfunction getBestScoringError(errors: NonUnionError[]) {\n return maxWithComparator(errors, (errorA, errorB) => {\n const aPathLength = getCombinedPathLength(errorA)\n const bPathLength = getCombinedPathLength(errorB)\n if (aPathLength !== bPathLength) {\n return aPathLength - bPathLength\n }\n return getErrorTypeScore(errorA) - getErrorTypeScore(errorB)\n })\n}\n\nfunction getCombinedPathLength(error: EngineValidationError) {\n let score = 0\n if (Array.isArray(error['selectionPath'])) {\n score += error['selectionPath'].length\n }\n\n if (Array.isArray(error['argumentPath'])) {\n score += error['argumentPath'].length\n }\n return score\n}\n\n/**\n * Function is invoked to determine most relevant error based on its type.\n * Specific numbers returned from this function do not really matter, it's only\n * important how they compare relatively to each other.\n *\n * Current logic is:\n * - InvalidArgumentValue/ValueTooLarge is treated as the best possible error to display\n * since when it is present we know that the field causing the error is defined on the schema\n * and provided value has correct type, it's just that value violates some other constraint.\n * - Next candidate is `InvalidArgumentType` error. We know the field user specified can exists in\n * this spot, it's just that value provided has incorrect type.\n * - All other engine-side errors follow. At that point it's difficult to say which of them is more relevant,\n * so we treat them equally. We might adjust this logic in the future.\n * - RequiredArgumentMissing is penalized because this error is often used to disambiguate\n * union types and what is required in one arm of the union might be fine to leave out in another\n * @param error\n * @returns\n */\nfunction getErrorTypeScore(error: EngineValidationError): number {\n switch (error.kind) {\n case 'InvalidArgumentValue':\n case 'ValueTooLarge':\n return 20\n case 'InvalidArgumentType':\n return 10\n case 'RequiredArgumentMissing':\n return -10\n default:\n return 0\n }\n}\n", "import { ErrorBasicBuilder, ErrorWriter } from './base'\nimport { SuggestionObjectValue } from './SuggestionObjectValue'\n\nexport class ObjectFieldSuggestion implements ErrorBasicBuilder {\n public isRequired = false\n constructor(\n readonly name: string,\n readonly value: string | SuggestionObjectValue,\n ) {}\n\n makeRequired() {\n this.isRequired = true\n return this\n }\n\n write(writer: ErrorWriter): void {\n const {\n colors: { green },\n } = writer.context\n\n writer.addMarginSymbol(green(this.isRequired ? '+' : '?'))\n writer.write(green(this.name))\n\n if (!this.isRequired) {\n writer.write(green('?'))\n }\n\n writer.write(green(`: `))\n if (typeof this.value === 'string') {\n writer.write(green(this.value))\n } else {\n writer.write(this.value)\n }\n }\n}\n", "export * from './AnyDeclarationBuilder'\nexport * from './ArraySpread'\nexport * from './ArrayType'\nexport * from './BasicBuilder'\nexport * from './Class'\nexport * from './ConditionalType'\nexport * from './ConstDeclaration'\nexport * from './DocComment'\nexport * from './Export'\nexport * from './ExportFrom'\nexport * from './File'\nexport * from './FunctionCall'\nexport * from './FunctionType'\nexport * from './GenericParameter'\nexport * from './helpers'\nexport * from './Import'\nexport * from './Interface'\nexport * from './IntersectionType'\nexport * from './KeyofType'\nexport * from './KeyType'\nexport * from './Method'\nexport * from './NamedType'\nexport * from './NamedValue'\nexport * from './NamespaceDeclaration'\nexport * from './ObjectType'\nexport * from './Parameter'\nexport * from './PrimitiveType'\nexport * from './Property'\nexport * from './stringify'\nexport * from './StringLiteralType'\nexport * from './TupleType'\nexport * from './TypeBuilder'\nexport * from './TypeDeclaration'\nexport * from './UnionType'\nexport * from './ValueBuilder'\nexport * from './WellKnownSymbol'\nexport * from './Writer'\n", "import type { BasicBuilder } from './BasicBuilder'\n\nexport const INDENT_SIZE = 2\n/**\n * Helper class for building long multi-line formatted strings from building blocks.\n * Can use either plain strings or `Builder` objects, that would encapsulate formatting logic.\n */\nexport class Writer<ContextType = undefined> {\n private lines: string[] = []\n private currentLine = ''\n private currentIndent = 0\n private marginSymbol?: string\n private afterNextNewLineCallback?: () => void\n\n constructor(\n startingIndent = 0,\n readonly context: ContextType,\n ) {\n this.currentIndent = startingIndent\n }\n\n /**\n * Adds provided value to the current line. Does not end the line.\n *\n * @param value\n * @returns\n */\n write(value: string | BasicBuilder<ContextType>): this {\n if (typeof value === 'string') {\n this.currentLine += value\n } else {\n value.write(this)\n }\n return this\n }\n\n /**\n * Adds several `values` to the current line, separated by `separator`. Both values and separator\n * can also be `Builder` instances for more advanced formatting.\n *\n * @param separator\n * @param values\n * @param writeItem allow to customize how individual item is written\n * @returns\n */\n writeJoined<T extends string | BasicBuilder<ContextType>>(\n separator: string | BasicBuilder<ContextType>,\n values: T[],\n writeItem: (item: T, writer: this) => void = (item, w) => w.write(item),\n ): this {\n const last = values.length - 1\n for (let i = 0; i < values.length; i++) {\n writeItem(values[i], this)\n if (i !== last) {\n this.write(separator)\n }\n }\n return this\n }\n\n /**\n * Adds a string to current line, flushes current line and starts a new line.\n * @param line\n * @returns\n */\n writeLine(line: string | BasicBuilder<ContextType>): this {\n return this.write(line).newLine()\n }\n\n /**\n * Flushes current line and starts a new line. New line starts at previously configured indentation level\n * @returns\n */\n newLine(): this {\n this.lines.push(this.indentedCurrentLine())\n this.currentLine = ''\n this.marginSymbol = undefined\n\n const afterNextNewLineCallback = this.afterNextNewLineCallback\n this.afterNextNewLineCallback = undefined\n afterNextNewLineCallback?.()\n return this\n }\n\n /**\n * Increases indentation level by 1, calls provided callback and then decreases indentation again.\n * Could be used for writing indented blocks of text:\n *\n * @example\n * ```ts\n * writer\n * .writeLine('{')\n * .withIndent(() => {\n * writer.writeLine('foo: 123');\n * writer.writeLine('bar: 456');\n * })\n * .writeLine('}')\n * ```\n * @param callback\n * @returns\n */\n withIndent(callback: (writer: this) => void): this {\n this.indent()\n callback(this)\n this.unindent()\n return this\n }\n\n /**\n * Calls provided callback next time when new line is started.\n * Callback is called after old line have already been flushed and a new\n * line have been started. Can be used for adding \"between the lines\" decorations,\n * such as underlines.\n *\n * @param callback\n * @returns\n */\n afterNextNewline(callback: () => void) {\n this.afterNextNewLineCallback = callback\n return this\n }\n\n /**\n * Increases indentation level of the current line by 1\n * @returns\n */\n indent(): this {\n this.currentIndent++\n return this\n }\n\n /**\n * Decreases indentation level of the current line by 1, if it is possible\n * @returns\n */\n unindent(): this {\n if (this.currentIndent > 0) {\n this.currentIndent--\n }\n return this\n }\n\n /**\n * Adds a symbol, that will replace the first character of the current line (including indentation)\n * when it is flushed. Can be used for adding markers to the line.\n *\n * Note: if indentation level of the line is 0, it will replace the first actually printed character\n * of the line. Use with caution.\n * @param symbol\n * @returns\n */\n addMarginSymbol(symbol: string): this {\n this.marginSymbol = symbol\n return this\n }\n\n toString() {\n return this.lines.concat(this.indentedCurrentLine()).join('\\n')\n }\n\n getCurrentLineLength() {\n return this.currentLine.length\n }\n\n private indentedCurrentLine(): string {\n const line = this.currentLine.padStart(this.currentLine.length + INDENT_SIZE * this.currentIndent)\n if (this.marginSymbol) {\n return this.marginSymbol + line.slice(1)\n }\n return line\n }\n}\n", "import { ErrorBasicBuilder, ErrorWriter } from './base'\nimport { Field } from './Field'\nimport { Value } from './Value'\n\nexport class ArrayField implements ErrorBasicBuilder, Field {\n constructor(public value: Value) {}\n write(writer: ErrorWriter): void {\n writer.write(this.value)\n }\n\n markAsError(): void {\n this.value.markAsError()\n }\n}\n", "import { BasicBuilder, Writer } from '@prisma/ts-builders'\nimport { bold, dim, green, red } from 'kleur/colors'\n\ntype ColorFn = (str: string) => string\nexport type Colors = {\n bold: ColorFn\n red: ColorFn\n green: ColorFn\n dim: ColorFn\n // if false, all color functions are useless\n readonly enabled: boolean\n}\n\nconst noop = (str: string) => str\n\nexport const inactiveColors: Colors = {\n bold: noop,\n red: noop,\n green: noop,\n dim: noop,\n enabled: false,\n}\n\nexport const activeColors: Colors = {\n bold,\n red,\n green,\n dim,\n enabled: true,\n}\n\nexport type ErrorRenderContext = {\n colors: Colors\n}\n\nexport type ErrorWriter = Writer<ErrorRenderContext>\nexport type ErrorBasicBuilder = BasicBuilder<ErrorRenderContext>\n\nexport const fieldsSeparator: ErrorBasicBuilder = {\n write(writer) {\n writer.writeLine(',')\n },\n}\n", "import { ErrorBasicBuilder, ErrorWriter } from './base'\n\nexport type ColorFn = (str: string) => string\n\nexport class FormattedString implements ErrorBasicBuilder {\n private isUnderlined = false\n private color: ColorFn = (str) => str\n constructor(public contents: string) {}\n\n underline(): this {\n this.isUnderlined = true\n return this\n }\n\n setColor(color: ColorFn): this {\n this.color = color\n return this\n }\n\n write(writer: ErrorWriter): void {\n const paddingSize = writer.getCurrentLineLength()\n writer.write(this.color(this.contents))\n if (this.isUnderlined) {\n writer.afterNextNewline(() => {\n writer.write(' '.repeat(paddingSize)).writeLine(this.color('~'.repeat(this.contents.length)))\n })\n }\n }\n}\n", "import { ErrorBasicBuilder, ErrorWriter } from './base'\nimport { ObjectValue } from './ObjectValue'\n\nexport abstract class Value implements ErrorBasicBuilder {\n abstract write(writer: ErrorWriter): void\n\n /**\n * Returns total width the value when it is rendered. Used\n * for determining underline width.\n */\n abstract getPrintWidth(): number\n\n public hasError = false\n\n markAsError(): this {\n this.hasError = true\n return this\n }\n\n abstract asObject(): ObjectValue | undefined\n}\n", "import { INDENT_SIZE } from '@prisma/ts-builders'\n\nimport { ArrayField } from './ArrayField'\nimport { ErrorWriter, fieldsSeparator } from './base'\nimport { FormattedString } from './FormattedString'\nimport { Value } from './Value'\n\nexport class ArrayValue extends Value {\n private items: ArrayField[] = []\n\n addItem(item: Value): this {\n this.items.push(new ArrayField(item))\n return this\n }\n\n getField(index: number): ArrayField | undefined {\n return this.items[index]\n }\n\n override getPrintWidth(): number {\n if (this.items.length === 0) {\n return 2\n }\n const maxItemWidth = Math.max(...this.items.map((item) => item.value.getPrintWidth()))\n return maxItemWidth + INDENT_SIZE\n }\n\n override write(writer: ErrorWriter): void {\n if (this.items.length === 0) {\n this.writeEmpty(writer)\n return\n }\n this.writeWithItems(writer)\n }\n\n private writeEmpty(writer: ErrorWriter) {\n const output = new FormattedString('[]')\n if (this.hasError) {\n output.setColor(writer.context.colors.red).underline()\n }\n writer.write(output)\n }\n\n private writeWithItems(writer: ErrorWriter) {\n const { colors } = writer.context\n\n writer\n .writeLine('[')\n .withIndent(() => writer.writeJoined(fieldsSeparator, this.items).newLine())\n .write(']')\n\n if (this.hasError) {\n writer.afterNextNewline(() => {\n writer.writeLine(colors.red('~'.repeat(this.getPrintWidth())))\n })\n }\n }\n\n override asObject(): undefined {\n return undefined\n }\n}\n", "import { INDENT_SIZE } from '@prisma/ts-builders'\n\nimport { ArrayValue } from './ArrayValue'\nimport { ErrorWriter, fieldsSeparator } from './base'\nimport { Field } from './Field'\nimport { FormattedString } from './FormattedString'\nimport { ObjectField } from './ObjectField'\nimport { ObjectFieldSuggestion } from './ObjectFieldSuggestion'\nimport { Value } from './Value'\n\ntype SelectionParent = {\n kind: 'include' | 'select'\n value: ObjectValue\n}\n\n/**\n * Class for representing object value within rendering tree. Also used for accessing\n * different fields of the object.\n *\n * Terminology used within:\n * - selection parent = either `select` or `include` property value. For example for object\n * `{ select: { posts: true }}`, selection parent is `{ posts: true }`\n * - sub selection: value of a property of selection parent. Can be deep. In that case, specified\n * path is expected to not contain either `select` or `include` values in between (the way engine reports `selectionPath`).\n * For example, for this query:\n *\n * {\n * include: {\n * posts: {\n * select: { attachments: { where: { published: true }} }\n * }\n * }\n * }\n * Value of sub selection at path [posts, attachments] is { where: { published: true }}\n */\nexport class ObjectValue extends Value {\n private fields: Record<string, ObjectField> = {}\n private suggestions: ObjectFieldSuggestion[] = []\n\n addField(field: ObjectField) {\n this.fields[field.name] = field\n }\n\n addSuggestion(suggestion: ObjectFieldSuggestion) {\n this.suggestions.push(suggestion)\n }\n\n getField(key: string): ObjectField | undefined {\n return this.fields[key]\n }\n\n getDeepField(path: string[]): Field | undefined {\n const [head, ...tail] = path\n const firstField = this.getField(head)\n if (!firstField) {\n return undefined\n }\n let field: Field = firstField\n for (const segment of tail) {\n let nextField: Field | undefined\n\n if (field.value instanceof ObjectValue) {\n nextField = field.value.getField(segment)\n } else if (field.value instanceof ArrayValue) {\n nextField = field.value.getField(Number(segment))\n }\n if (!nextField) {\n return undefined\n }\n field = nextField\n }\n return field\n }\n\n getDeepFieldValue(path: string[]) {\n if (path.length === 0) {\n return this\n }\n return this.getDeepField(path)?.value\n }\n\n hasField(key: string) {\n return Boolean(this.getField(key))\n }\n\n removeAllFields() {\n this.fields = {}\n }\n\n removeField(key: string) {\n delete this.fields[key]\n }\n\n getFields() {\n return this.fields\n }\n\n isEmpty(): boolean {\n return Object.keys(this.fields).length === 0\n }\n\n getFieldValue(key: string): Value | undefined {\n return this.getField(key)?.value\n }\n\n getDeepSubSelectionValue(path: string[]): Value | undefined {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let selection: Value = this\n for (const segment of path) {\n if (!(selection instanceof ObjectValue)) {\n return undefined\n }\n const next = selection.getSubSelectionValue(segment)\n if (!next) {\n return undefined\n }\n\n selection = next\n }\n\n return selection\n }\n\n getDeepSelectionParent(path: string[]): SelectionParent | undefined {\n const thisParent = this.getSelectionParent()\n if (!thisParent) {\n return undefined\n }\n\n let parent = thisParent\n\n for (const segment of path) {\n const next = parent.value.getFieldValue(segment)\n if (!next || !(next instanceof ObjectValue)) {\n return undefined\n }\n\n const nextParent = next.getSelectionParent()\n if (!nextParent) {\n return undefined\n }\n parent = nextParent\n }\n\n return parent\n }\n\n getSelectionParent(): SelectionParent | undefined {\n const select = this.getField('select')?.value.asObject()\n if (select) {\n return { kind: 'select', value: select }\n }\n\n const include = this.getField('include')?.value.asObject()\n if (include) {\n return { kind: 'include', value: include }\n }\n return undefined\n }\n\n getSubSelectionValue(key: string): Value | undefined {\n return this.getSelectionParent()?.value.fields[key].value\n }\n\n override getPrintWidth(): number {\n const fields = Object.values(this.fields)\n if (fields.length == 0) {\n return 2 // {}\n }\n const maxFieldWidth = Math.max(...fields.map((f) => f.getPrintWidth()))\n return maxFieldWidth + INDENT_SIZE\n }\n\n override write(writer: ErrorWriter): void {\n const fields = Object.values(this.fields)\n if (fields.length === 0 && this.suggestions.length === 0) {\n this.writeEmpty(writer)\n return\n }\n\n this.writeWithContents(writer, fields)\n }\n\n override asObject(): ObjectValue {\n return this\n }\n\n private writeEmpty(writer: ErrorWriter) {\n const output = new FormattedString('{}')\n if (this.hasError) {\n output.setColor(writer.context.colors.red).underline()\n }\n\n writer.write(output)\n }\n\n private writeWithContents(writer: ErrorWriter, fields: ObjectField[]) {\n writer.writeLine('{').withIndent(() => {\n writer.writeJoined(fieldsSeparator, [...fields, ...this.suggestions]).newLine()\n })\n\n writer.write('}')\n if (this.hasError) {\n writer.afterNextNewline(() => {\n writer.writeLine(writer.context.colors.red('~'.repeat(this.getPrintWidth())))\n })\n }\n }\n}\n", "import { ErrorWriter } from './base'\nimport { FormattedString } from './FormattedString'\nimport { Value } from './Value'\n\nexport class ScalarValue extends Value {\n constructor(readonly text: string) {\n super()\n }\n\n override getPrintWidth(): number {\n return this.text.length\n }\n\n override write(writer: ErrorWriter): void {\n const string = new FormattedString(this.text)\n if (this.hasError) {\n string.underline().setColor(writer.context.colors.red)\n }\n writer.write(string)\n }\n\n override asObject(): undefined {\n return undefined\n }\n}\n", "import { ErrorBasicBuilder, ErrorWriter, fieldsSeparator } from './base'\n\nexport class SuggestionObjectValue implements ErrorBasicBuilder {\n private fields: ErrorBasicBuilder[] = []\n\n addField(name: string, value: string) {\n this.fields.push({\n write(writer) {\n const { green, dim } = writer.context.colors\n writer.write(green(dim(`${name}: ${value}`))).addMarginSymbol(green(dim('+')))\n },\n })\n return this\n }\n\n write(writer: ErrorWriter): void {\n const {\n colors: { green },\n } = writer.context\n writer\n .writeLine(green('{'))\n .withIndent(() => {\n writer.writeJoined(fieldsSeparator, this.fields).newLine()\n })\n .write(green('}'))\n .addMarginSymbol(green('+'))\n }\n}\n", "import { uncapitalize } from '@prisma/client-common'\nimport { ObjectEnumValue } from '@prisma/client-runtime-utils'\nimport { Writer } from '@prisma/ts-builders'\n\nimport { ErrorFormat } from '../../getPrismaClient'\nimport { isValidDate } from '../../utils/date'\nimport { isDecimalJsLike } from '../../utils/decimalJsLike'\nimport { isFieldRef } from '../model/FieldRef'\nimport { ArrayValue } from './ArrayValue'\nimport { activeColors, Colors, ErrorBasicBuilder, ErrorWriter, inactiveColors } from './base'\nimport { ObjectField } from './ObjectField'\nimport { ObjectValue } from './ObjectValue'\nimport { ScalarValue } from './ScalarValue'\n\ntype MessageRender = (colors: Colors) => string\n\nexport class ArgumentsRenderingTree implements ErrorBasicBuilder {\n readonly arguments: ObjectValue\n private errorMessages: MessageRender[] = []\n\n constructor(args: ObjectValue) {\n this.arguments = args\n }\n\n write(writer: ErrorWriter): void {\n writer.write(this.arguments)\n }\n\n addErrorMessage(renderer: MessageRender) {\n this.errorMessages.push(renderer)\n }\n\n renderAllMessages(colors: Colors): string {\n return this.errorMessages.map((messageRenderer) => messageRenderer(colors)).join('\\n')\n }\n}\n\n/**\n * Given JS call arguments, produces rendering tree for outputting rich errors into the console\n * Difference between rendering tree and plain object is that fields and values can have different attributes:\n * colors, underlines, markers on the margins. `applyValidationError` function will then apply specific formatting\n * to the rendering tree.\n *\n * @param args\n * @returns\n */\nexport function buildArgumentsRenderingTree(args: Record<PropertyKey, unknown>): ArgumentsRenderingTree {\n return new ArgumentsRenderingTree(buildInputObject(args))\n}\n\nfunction buildInputObject(inputObject: Record<PropertyKey, unknown>) {\n const object = new ObjectValue()\n\n for (const [key, value] of Object.entries(inputObject)) {\n const field = new ObjectField(key, buildInputValue(value))\n object.addField(field)\n }\n return object\n}\n\nfunction buildInputValue(value: unknown) {\n if (typeof value === 'string') {\n return new ScalarValue(JSON.stringify(value))\n }\n\n if (typeof value === 'number' || typeof value === 'boolean') {\n return new ScalarValue(String(value))\n }\n\n if (typeof value === 'bigint') {\n return new ScalarValue(`${value}n`)\n }\n\n if (value === null) {\n return new ScalarValue('null')\n }\n\n if (value === undefined) {\n return new ScalarValue('undefined')\n }\n\n if (isDecimalJsLike(value)) {\n return new ScalarValue(`new Prisma.Decimal(\"${value.toFixed()}\")`)\n }\n\n if (value instanceof Uint8Array) {\n if (Buffer.isBuffer(value)) {\n return new ScalarValue(`Buffer.alloc(${value.byteLength})`)\n }\n return new ScalarValue(`new Uint8Array(${value.byteLength})`)\n }\n\n if (value instanceof Date) {\n const dateStr = isValidDate(value) ? value.toISOString() : 'Invalid Date'\n return new ScalarValue(`new Date(\"${dateStr}\")`)\n }\n\n if (value instanceof ObjectEnumValue) {\n return new ScalarValue(`Prisma.${value._getName()}`)\n }\n\n if (isFieldRef(value)) {\n return new ScalarValue(`prisma.${uncapitalize(value.modelName)}.$fields.${value.name}`)\n }\n\n if (Array.isArray(value)) {\n return buildInputArray(value)\n }\n\n if (typeof value === 'object') {\n return buildInputObject(value as Record<PropertyKey, unknown>)\n }\n\n return new ScalarValue(Object.prototype.toString.call(value))\n}\n\nfunction buildInputArray(array: unknown[]) {\n const result = new ArrayValue()\n for (const item of array) {\n result.addItem(buildInputValue(item))\n }\n return result\n}\n\nexport function renderArgsTree(argsTree: ArgumentsRenderingTree, errorFormat: ErrorFormat) {\n const colors = errorFormat === 'pretty' ? activeColors : inactiveColors\n\n const message = argsTree.renderAllMessages(colors)\n const args = new Writer(0, { colors }).write(argsTree).toString()\n\n return { message, args }\n}\n", "import { FieldRef } from '../types/exported/FieldRef'\n\nexport class FieldRefImpl<Model, FieldType> implements FieldRef<Model, FieldType> {\n public readonly modelName: Model\n public readonly name: string\n public readonly typeName: FieldType\n public readonly isList: boolean\n public readonly isEnum: boolean\n\n constructor(modelName: Model, name: string, fieldType: FieldType, isList: boolean, isEnum: boolean) {\n this.modelName = modelName\n this.name = name\n this.typeName = fieldType\n this.isList = isList\n this.isEnum = isEnum\n }\n\n _toGraphQLInputType() {\n const listPrefix = this.isList ? `List` : ''\n const enumPrefix = this.isEnum ? 'Enum' : ''\n\n return `${listPrefix}${enumPrefix}${this.typeName}FieldRefInput<${this.modelName}>`\n }\n}\n\nexport function isFieldRef(value: unknown): value is FieldRef<string, unknown> {\n return value instanceof FieldRefImpl\n}\n", "import { ErrorBasicBuilder, ErrorWriter } from './base'\nimport { Field } from './Field'\nimport { FormattedString } from './FormattedString'\nimport { Value } from './Value'\n\nconst separator = ': '\nexport class ObjectField implements ErrorBasicBuilder, Field {\n hasError = false\n constructor(\n readonly name: string,\n public value: Value,\n ) {}\n\n markAsError() {\n this.hasError = true\n }\n\n getPrintWidth() {\n return this.name.length + this.value.getPrintWidth() + separator.length\n }\n\n write(writer: ErrorWriter): void {\n const name = new FormattedString(this.name)\n if (this.hasError) {\n name.underline().setColor(writer.context.colors.red)\n }\n writer.write(name).write(separator).write(this.value)\n }\n}\n", "/**\n * Transforms a model name coming from the DMMF to a runtime model name.\n * @param name\n * @returns\n */\nexport function dmmfToJSModelName(name: string) {\n return name.replace(/^./, (str) => str.toLowerCase())\n}\n", "import { Cache } from '@prisma/client-common'\nimport { mapObjectValues } from '@prisma/internals'\n\nimport { dmmfToJSModelName } from '../model/utils/dmmfToJSModelName'\nimport { ExtensionArgs, ResultArg, ResultArgsFieldCompute } from '../types/exported/ExtensionArgs'\nimport { Omission, Selection } from '../types/exported/JsApi'\n\nexport type ComputedField = {\n name: string\n needs: string[]\n compute: ResultArgsFieldCompute\n}\n\nexport type ComputedFieldsMap = {\n [fieldName: string]: ComputedField\n}\n\n/**\n * Given the list of previously resolved computed fields, new extension and dmmf model name, produces a map\n * of all computed fields that may be applied to this model, accounting for all previous and past extensions.\n *\n * All naming conflicts which could be produced by the plain list of extensions are resolved as follows:\n * - extension, that declared later always wins\n * - in a single extension, specific model takes precedence over $allModels\n *\n * Additionally, resolves all `needs` dependencies down to the model fields. For example,\n * if `nameAndTitle` field depends on `fullName` computed field and `title` model field and\n * `fullName` field depends on `firstName` and `lastName` field, full list of `nameAndTitle` dependencies\n * would be `firstName`, `lastName`, `title`.\n * @param previousComputedFields\n * @param extension\n * @param dmmfModelName\n * @returns\n */\nexport function getComputedFields(\n previousComputedFields: ComputedFieldsMap | undefined,\n extension: ExtensionArgs,\n dmmfModelName: string,\n) {\n const jsName = dmmfToJSModelName(dmmfModelName)\n if (!extension.result || !(extension.result.$allModels || extension.result[jsName])) {\n return previousComputedFields\n }\n\n return resolveDependencies({\n ...previousComputedFields,\n ...getComputedFieldsFromModel(extension.name, previousComputedFields, extension.result.$allModels),\n ...getComputedFieldsFromModel(extension.name, previousComputedFields, extension.result[jsName]),\n })\n}\n\nexport function resolveDependencies(computedFields: ComputedFieldsMap): ComputedFieldsMap {\n const cache = new Cache<string, string[]>()\n const resolveNeeds = (fieldName: string, visitedFields: Set<string>) => {\n return cache.getOrCreate(fieldName, () => {\n if (visitedFields.has(fieldName)) {\n return [fieldName]\n }\n visitedFields.add(fieldName)\n if (!computedFields[fieldName]) {\n return [fieldName]\n }\n return computedFields[fieldName].needs.flatMap((fieldDep) => resolveNeeds(fieldDep, visitedFields))\n })\n }\n\n return mapObjectValues(computedFields, (field) => {\n return {\n ...field,\n needs: resolveNeeds(field.name, new Set()),\n }\n })\n}\n\nfunction getComputedFieldsFromModel(\n name: string | undefined,\n previousComputedFields: ComputedFieldsMap | undefined,\n modelResult: ResultArg | undefined,\n): ComputedFieldsMap {\n if (!modelResult) {\n return {}\n }\n\n return mapObjectValues(modelResult, ({ needs, compute }, fieldName) => ({\n name: fieldName,\n needs: needs ? Object.keys(needs).filter((key) => needs[key]) : [],\n compute: composeCompute(previousComputedFields, fieldName, compute),\n }))\n}\n\nfunction composeCompute(\n previousComputedFields: ComputedFieldsMap | undefined,\n fieldName: string,\n nextCompute: ResultArgsFieldCompute,\n): ResultArgsFieldCompute {\n const previousCompute = previousComputedFields?.[fieldName]?.compute\n if (!previousCompute) {\n return nextCompute\n }\n return (model) => {\n return nextCompute({ ...model, [fieldName]: previousCompute(model) })\n }\n}\n\nexport function computeEngineSideSelection(\n selection: Selection,\n computedFields: ComputedFieldsMap | undefined,\n): Selection {\n if (!computedFields) {\n return selection\n }\n const result = { ...selection }\n\n for (const field of Object.values(computedFields)) {\n if (!selection[field.name]) {\n continue\n }\n\n for (const dependency of field.needs) {\n result[dependency] = true\n }\n }\n return result\n}\n\n/**\n * Given user-supplied omissions, computes the results to send to the engine, taking\n * into account dependencies of the computed field. Consider following example:\n *\n * ```\n * const xprisma = prisma.$extends({\n * result: {\n * user: {\n * sanitizedPassword: {\n * needs: { password: true },\n * compute(user) {\n * return sanitze(user.password)\n * },\n * },\n * },\n * },\n * })\n *\n * const user = await xprisma.user.findFirstOrThrow({\n * omit: {\n * password: true,\n * },\n * })\n * ```\n *\n * In that case, user wants to omit the `password` but not `sanitizedPassword`.\n * Since `sanitizedPassword` can not be computed without `password`, we can not let\n * the engine handle omission in this case - we have to still query `password` from the\n * database and omit it on the client, after computing `sanitizedPassword`.\n *\n * This function removes the omission (thus, including the field into result set) if it is a dependency of\n * a non-omitted computed field. Client-side omission after we get a response is handled by `applyResultExtensions`\n *\n * @param omission\n * @param computedFields\n * @returns\n */\nexport function computeEngineSideOmissions(\n omission: Omission,\n computedFields: ComputedFieldsMap | undefined,\n): Omission {\n if (!computedFields) {\n return omission\n }\n const result = { ...omission }\n\n for (const field of Object.values(computedFields)) {\n if (omission[field.name]) {\n continue\n }\n\n for (const dependency of field.needs) {\n delete result[dependency]\n }\n }\n return result\n}\n", "import { Cache, lazyProperty } from '@prisma/client-common'\n\nimport { dmmfToJSModelName } from '../model/utils/dmmfToJSModelName'\nimport { ClientArg, ExtensionArgs, ModelArg, QueryOptionsCb } from '../types/exported/ExtensionArgs'\nimport { BatchQueryOptionsCb, QueryOptionsPrivate } from '../types/internal/ExtensionsInternalArgs'\nimport { ComputedFieldsMap, getComputedFields } from './resultUtils'\n\nclass MergedExtensionsListNode {\n private computedFieldsCache = new Cache<string, ComputedFieldsMap | undefined>()\n private modelExtensionsCache = new Cache<string, ModelArg | undefined>()\n private queryCallbacksCache = new Cache<string, QueryOptionsCb[]>()\n\n private clientExtensions = lazyProperty(() => {\n if (!this.extension.client) {\n return this.previous?.getAllClientExtensions()\n }\n\n return {\n ...this.previous?.getAllClientExtensions(),\n ...this.extension.client,\n }\n })\n\n private batchCallbacks = lazyProperty(() => {\n const previous: BatchQueryOptionsCb[] = this.previous?.getAllBatchQueryCallbacks() ?? []\n const newCb = (this.extension as QueryOptionsPrivate).query?.$__internalBatch\n if (!newCb) {\n return previous\n }\n return previous.concat(newCb)\n })\n\n constructor(\n public extension: ExtensionArgs,\n public previous?: MergedExtensionsListNode,\n ) {}\n\n getAllComputedFields(dmmfModelName: string): ComputedFieldsMap | undefined {\n return this.computedFieldsCache.getOrCreate(dmmfModelName, () => {\n return getComputedFields(this.previous?.getAllComputedFields(dmmfModelName), this.extension, dmmfModelName)\n })\n }\n\n getAllClientExtensions(): ClientArg | undefined {\n return this.clientExtensions.get()\n }\n\n getAllModelExtensions(dmmfModelName: string): ModelArg | undefined {\n return this.modelExtensionsCache.getOrCreate(dmmfModelName, () => {\n const jsModelName = dmmfToJSModelName(dmmfModelName)\n if (!this.extension.model || !(this.extension.model[jsModelName] || this.extension.model.$allModels)) {\n return this.previous?.getAllModelExtensions(dmmfModelName)\n }\n\n return {\n ...this.previous?.getAllModelExtensions(dmmfModelName),\n ...this.extension.model.$allModels,\n ...this.extension.model[jsModelName],\n }\n })\n }\n\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n getAllQueryCallbacks(jsModelName: string | '$none', operation: string) {\n return this.queryCallbacksCache.getOrCreate(`${jsModelName}:${operation}`, () => {\n const prevCbs = this.previous?.getAllQueryCallbacks(jsModelName, operation) ?? []\n const newCbs: QueryOptionsCb[] = []\n const query = this.extension.query\n\n if (!query || !(query[jsModelName] || query['$allModels'] || query[operation] || query['$allOperations'])) {\n return prevCbs\n }\n\n if (query[jsModelName] !== undefined) {\n if (query[jsModelName][operation] !== undefined) {\n newCbs.push(query[jsModelName][operation])\n }\n\n // when the model-bound extension has a wildcard for the operation\n if (query[jsModelName]['$allOperations'] !== undefined) {\n newCbs.push(query[jsModelName]['$allOperations'])\n }\n }\n\n // when the extension isn't model-bound, apply it to all models\n // '$none' is a special case for top-level operations without model\n if (jsModelName !== '$none' && query['$allModels'] !== undefined) {\n if (query['$allModels'][operation] !== undefined) {\n newCbs.push(query['$allModels'][operation])\n }\n\n // when the non-model-bound extension has a wildcard for the operation\n if (query['$allModels']['$allOperations'] !== undefined) {\n newCbs.push(query['$allModels']['$allOperations'])\n }\n }\n\n // when the extension is not bound to a model & is a top-level operation\n if (query[operation] !== undefined) {\n newCbs.push(query[operation] as QueryOptionsCb)\n }\n\n // when the extension is not bound to a model & is any top-level operation\n if (query['$allOperations'] !== undefined) {\n newCbs.push(query['$allOperations'] as QueryOptionsCb)\n }\n\n return prevCbs.concat(newCbs)\n })\n }\n\n getAllBatchQueryCallbacks() {\n return this.batchCallbacks.get()\n }\n}\n\n/**\n * Class that holds the list of all extensions, applied to particular instance,\n * as well as resolved versions of the components that need to apply on\n * different levels. Main idea of this class: avoid re-resolving as much of the\n * stuff as possible when new extensions are added while also delaying the\n * resolve until the point it is actually needed. For example, computed fields\n * of the model won't be resolved unless the model is actually queried. Neither\n * adding extensions with `client` component only cause other components to\n * recompute.\n */\nexport class MergedExtensionsList {\n private constructor(private head?: MergedExtensionsListNode) {}\n\n static empty() {\n return new MergedExtensionsList()\n }\n\n static single(extension: ExtensionArgs) {\n return new MergedExtensionsList(new MergedExtensionsListNode(extension))\n }\n\n isEmpty(): boolean {\n return this.head === undefined\n }\n\n append(extension: ExtensionArgs) {\n return new MergedExtensionsList(new MergedExtensionsListNode(extension, this.head))\n }\n\n getAllComputedFields(dmmfModelName: string): ComputedFieldsMap | undefined {\n return this.head?.getAllComputedFields(dmmfModelName)\n }\n\n getAllClientExtensions() {\n return this.head?.getAllClientExtensions()\n }\n\n getAllModelExtensions(dmmfModelName: string) {\n return this.head?.getAllModelExtensions(dmmfModelName)\n }\n\n getAllQueryCallbacks(jsModelName: string, operation: string) {\n return this.head?.getAllQueryCallbacks(jsModelName, operation) ?? []\n }\n\n getAllBatchQueryCallbacks() {\n return this.head?.getAllBatchQueryCallbacks() ?? []\n }\n}\n", "import { Param } from '../types/exported/Param'\n\nexport class ParamImpl<Type, Name extends string> implements Param<Type, Name> {\n constructor(public readonly name: Name) {}\n}\n\nexport function isParam(value: unknown): value is Param<unknown, string> {\n return value instanceof ParamImpl\n}\n\nexport function createParam(name: string): Param<unknown, string> {\n return new ParamImpl(name)\n}\n", "// private symbol that prevents direct construction of a class\nconst secret = Symbol()\n\nexport class Skip {\n constructor(param?: symbol) {\n if (param !== secret) {\n throw new Error(`Skip instance can not be constructed directly`)\n }\n }\n\n ifUndefined<T>(value: T | undefined): T | Skip {\n if (value === undefined) {\n return skip\n }\n return value\n }\n}\n\nexport const skip = new Skip(secret)\n\nexport function isSkip(value: unknown): value is Skip {\n return value instanceof Skip\n}\n", "import { BaseDMMF, lazyProperty, RuntimeDataModel } from '@prisma/client-common'\n\nexport function defineDmmfProperty(target: object, runtimeDataModel: RuntimeDataModel) {\n const dmmfLazy = lazyProperty(() => runtimeDataModelToBaseDmmf(runtimeDataModel))\n\n Object.defineProperty(target, 'dmmf', {\n get: () => dmmfLazy.get(),\n })\n}\n\nfunction runtimeDataModelToBaseDmmf(runtimeDataModel: RuntimeDataModel): BaseDMMF {\n if (TARGET_BUILD_TYPE === 'wasm-compiler-edge') {\n throw new Error('Prisma.dmmf is not available when running in edge runtimes.')\n }\n\n return {\n datamodel: {\n models: buildDMMFList(runtimeDataModel.models),\n enums: buildDMMFList(runtimeDataModel.enums),\n types: buildDMMFList(runtimeDataModel.types),\n },\n }\n}\n\nfunction buildDMMFList<T>(map: Record<string, T>): Array<T & { name: string }> {\n return Object.entries(map).map(([name, props]) => ({ name, ...props }))\n}\n", "type TypedSqlInternal = {\n sql: string\n values: readonly unknown[]\n}\n\nconst internals = new WeakMap<TypedSql<any, any>, TypedSqlInternal>()\nconst TypedSqlMarker = '$$PrismaTypedSql'\n\nexport declare const PrivateResultType: unique symbol\n\nexport class TypedSql<Values extends readonly unknown[], Result> {\n declare [PrivateResultType]: Result\n\n constructor(sql: string, values: Values) {\n internals.set(this, {\n sql,\n values,\n })\n\n Object.defineProperty(this, TypedSqlMarker, { value: TypedSqlMarker })\n }\n\n get sql(): string {\n return internals.get(this)!.sql\n }\n\n get values(): Values {\n return internals.get(this)!.values as Values\n }\n}\n\nexport type UnknownTypedSql = TypedSql<unknown[], unknown>\n\nexport function makeTypedQueryFactory(sql: string) {\n return (...values) => new TypedSql(sql, values)\n}\n\n// used so we could detect typed sql instances, created by different instance of runtime\n// or after hmr trigger\nexport function isTypedSql(value: unknown): value is UnknownTypedSql {\n return value != null && value[TypedSqlMarker] === TypedSqlMarker\n}\n", "import type { Context } from '@opentelemetry/api'\nimport { GetPrismaClientConfig, RuntimeDataModel } from '@prisma/client-common'\nimport { RawValue, Sql } from '@prisma/client-runtime-utils'\nimport { clearLogs, Debug } from '@prisma/debug'\nimport type { SqlDriverAdapterFactory } from '@prisma/driver-adapter-utils'\nimport type { ExtendedSpanOptions, TracingHelper } from '@prisma/instrumentation-contract'\nimport { logger } from '@prisma/internals'\nimport type { SqlCommenterPlugin } from '@prisma/sqlcommenter'\nimport { AsyncResource } from 'async_hooks'\nimport { EventEmitter } from 'events'\n\nimport { PrismaClientInitializationError, PrismaClientValidationError } from '.'\nimport { addProperty, createCompositeProxy, removeProperties } from './core/compositeProxy'\nimport { BatchTransactionOptions, Engine, EngineConfig, Options } from './core/engines'\nimport { AccelerateEngineConfig, AccelerateExtensionFetchDecorator } from './core/engines/common/Engine'\nimport { EngineEvent, LogEmitter } from './core/engines/common/types/Events'\nimport type * as Transaction from './core/engines/common/types/Transaction'\nimport { prettyPrintArguments } from './core/errorRendering/prettyPrintArguments'\nimport { $extends } from './core/extensions/$extends'\nimport { applyAllResultExtensions } from './core/extensions/applyAllResultExtensions'\nimport { applyQueryExtensions } from './core/extensions/applyQueryExtensions'\nimport { MergedExtensionsList } from './core/extensions/MergedExtensionsList'\nimport { getEngineInstance } from './core/init/getEngineInstance'\nimport { GlobalOmitOptions, serializeJsonQuery } from './core/jsonProtocol/serializeJsonQuery'\nimport {\n applyModelsAndClientExtensions,\n unApplyModelsAndClientExtensions,\n} from './core/model/applyModelsAndClientExtensions'\nimport { rawCommandArgsMapper } from './core/raw-query/rawCommandArgsMapper'\nimport {\n checkAlter,\n rawQueryArgsMapper,\n sqlMiddlewareArgsMapper,\n templateStringMiddlewareArgsMapper,\n} from './core/raw-query/rawQueryArgsMapper'\nimport { createPrismaPromiseFactory } from './core/request/createPrismaPromise'\nimport {\n PrismaPromise,\n PrismaPromiseInteractiveTransaction,\n PrismaPromiseTransaction,\n} from './core/request/PrismaPromise'\nimport { UserArgs } from './core/request/UserArgs'\nimport { getTracingHelper } from './core/tracing/TracingHelper'\nimport { getLockCountPromise } from './core/transaction/utils/createLockCountPromise'\nimport { itxClientDenyList } from './core/types/exported/itxClientDenyList'\nimport { JsInputValue } from './core/types/exported/JsApi'\nimport { RawQueryArgs } from './core/types/exported/RawQueryArgs'\nimport { UnknownTypedSql } from './core/types/exported/TypedSql'\nimport { getLogLevel } from './getLogLevel'\nimport type { QueryMiddlewareParams } from './QueryMiddlewareParams'\nimport { RequestHandler } from './RequestHandler'\nimport { CallSite, getCallSite } from './utils/CallSite'\nimport { clientVersion } from './utils/clientVersion'\nimport { validatePrismaClientOptions } from './utils/validatePrismaClientOptions'\nimport { waitForBatch } from './utils/waitForBatch'\n\nconst debug = Debug('prisma:client')\n\ndeclare global {\n // eslint-disable-next-line no-var\n var NODE_CLIENT: true\n const TARGET_BUILD_TYPE: 'wasm-compiler-edge' | 'client'\n}\n\n// used by esbuild for tree-shaking\ntypeof globalThis === 'object' ? (globalThis.NODE_CLIENT = true) : 0\n\nexport type ErrorFormat = 'pretty' | 'colorless' | 'minimal'\n\n/**\n * Since Prisma 7, a PrismaClient needs either an adapter or an accelerateUrl.\n * The two options are mutually exclusive.\n */\ntype PrismaClientMutuallyExclusiveOptions =\n | {\n /**\n * Instance of a Driver Adapter, e.g., like one provided by `@prisma/adapter-pg`.\n */\n adapter: SqlDriverAdapterFactory\n accelerateUrl?: never\n }\n | {\n /**\n * Prisma Accelerate URL allowing the client to connect through Accelerate instead of a direct database.\n */\n accelerateUrl: string\n adapter?: never\n }\n\nexport type PrismaClientOptions = PrismaClientMutuallyExclusiveOptions & {\n /**\n * @default \"colorless\"\n */\n errorFormat?: ErrorFormat\n\n /**\n * The default values for Transaction options\n * maxWait ?= 2000\n * timeout ?= 5000\n */\n transactionOptions?: Transaction.Options\n\n /**\n * @example\n * \\`\\`\\`\n * // Defaults to stdout\n * log: ['query', 'info', 'warn']\n *\n * // Emit as events\n * log: [\n * { emit: 'stdout', level: 'query' },\n * { emit: 'stdout', level: 'info' },\n * { emit: 'stdout', level: 'warn' }\n * ]\n * \\`\\`\\`\n * Read more in our [docs](https://pris.ly/d/logging).\n */\n log?: Array<LogLevel | LogDefinition>\n\n omit?: GlobalOmitOptions\n\n /**\n * SQL commenter plugins that add metadata to SQL queries as comments.\n * Comments follow the sqlcommenter format: https://google.github.io/sqlcommenter/\n *\n * @example\n * ```ts\n * new PrismaClient({\n * adapter: new PrismaPg({ connectionString }),\n * comments: [\n * traceContext(),\n * queryInsights(),\n * ],\n * })\n * ```\n */\n comments?: SqlCommenterPlugin[]\n\n /**\n * @internal\n * You probably don't want to use this. \\`__internal\\` is used by internal tooling.\n */\n __internal?: {\n debug?: boolean\n /** This can be used for testing purposes */\n configOverride?: (config: GetPrismaClientConfig) => GetPrismaClientConfig\n }\n}\n\nexport type Unpacker = (data: any) => any\n\nexport type InternalRequestParams = {\n /**\n * The original client method being called.\n * Even though the rootField / operation can be changed,\n * this method stays as it is, as it's what the user's\n * code looks like\n */\n clientMethod: string // TODO what is this\n /**\n * Name of js model that triggered the request. Might be used\n * for warnings or error messages\n */\n jsModelName?: string\n // Extra headers for data proxy.\n callsite?: CallSite\n transaction?: PrismaPromiseTransaction\n unpacker?: Unpacker // TODO what is this\n otelParentCtx?: Context\n /** Used to \"desugar\" a user input into an \"expanded\" one */\n argsMapper?: (args?: UserArgs) => UserArgs\n\n /** Used to convert args for middleware and back */\n middlewareArgsMapper?: MiddlewareArgsMapper<unknown, unknown>\n /** Used for Accelerate client extension via Data Proxy */\n customDataProxyFetch?: AccelerateExtensionFetchDecorator\n} & Omit<QueryMiddlewareParams, 'runInTransaction'>\n\nexport type MiddlewareArgsMapper<RequestArgs, MiddlewareArgs> = {\n requestArgsToMiddlewareArgs(requestArgs: RequestArgs): MiddlewareArgs\n middlewareArgsToRequestArgs(middlewareArgs: MiddlewareArgs): RequestArgs\n}\n\nconst noopMiddlewareArgsMapper: MiddlewareArgsMapper<unknown, unknown> = {\n requestArgsToMiddlewareArgs: (param) => param,\n middlewareArgsToRequestArgs: (param) => param,\n}\n\n/* Types for Logging */\nexport type LogLevel = 'info' | 'query' | 'warn' | 'error'\nexport type LogDefinition = {\n level: LogLevel\n emit: 'stdout' | 'event'\n}\n\nexport type QueryEvent = {\n timestamp: Date\n query: string\n params: string\n duration: number\n target: string\n}\n\nexport type LogEvent = {\n timestamp: Date\n message: string\n target: string\n}\n/* End Types for Logging */\n\ntype ExtendedEventType = LogLevel | 'beforeExit'\ntype EventCallback<E extends ExtendedEventType> = [E] extends ['beforeExit']\n ? () => Promise<void>\n : [E] extends [LogLevel]\n ? (event: EngineEvent<E>) => void\n : never\n\nconst TX_ID = Symbol.for('prisma.client.transaction.id')\n\nconst BatchTxIdCounter = {\n id: 0,\n nextId() {\n return ++this.id\n },\n}\n\nexport type Client =\n ReturnType<typeof getPrismaClient> extends new (optionsArg: PrismaClientOptions) => infer T ? T : never\n\nexport function getPrismaClient(config: GetPrismaClientConfig) {\n class PrismaClient {\n _originalClient = this\n _runtimeDataModel: RuntimeDataModel\n _requestHandler: RequestHandler\n _connectionPromise?: Promise<any>\n _disconnectionPromise?: Promise<any>\n _engineConfig: EngineConfig\n _accelerateEngineConfig: AccelerateEngineConfig\n _clientVersion: string\n _errorFormat: ErrorFormat\n _tracingHelper: TracingHelper\n _previewFeatures: string[]\n _activeProvider: string\n _globalOmit?: GlobalOmitOptions\n _extensions: MergedExtensionsList\n /**\n * @remarks This is used internally by Policy, do not rename or remove\n */\n _engine: Engine\n /**\n * A fully constructed/applied Client that references the parent\n * PrismaClient. This is used for Client extensions only.\n */\n _appliedParent: PrismaClient\n _createPrismaPromise = createPrismaPromiseFactory()\n\n constructor(optionsArg: PrismaClientOptions) {\n if (!optionsArg) {\n throw new PrismaClientInitializationError(\n `\\\n\\`PrismaClient\\` needs to be constructed with a non-empty, valid \\`PrismaClientOptions\\`:\n\n\\`\\`\\`\nnew PrismaClient({\n ...\n})\n\\`\\`\\`\n\nor\n\n\\`\\`\\`\nconstructor() {\n super({ ... });\n}\n\\`\\`\\`\n `,\n clientVersion,\n )\n }\n config = optionsArg.__internal?.configOverride?.(config) ?? config\n validatePrismaClientOptions(optionsArg, config)\n\n // prevents unhandled error events when users do not explicitly listen to them\n const logEmitter = new EventEmitter().on('error', () => {}) as LogEmitter\n\n this._extensions = MergedExtensionsList.empty()\n this._previewFeatures = config.previewFeatures\n this._clientVersion = config.clientVersion ?? clientVersion\n this._activeProvider = config.activeProvider\n this._globalOmit = optionsArg?.omit\n this._tracingHelper = getTracingHelper()\n\n /**\n * Initialise and validate the Driver Adapter, if provided.\n */\n\n let adapter: SqlDriverAdapterFactory | undefined\n if (optionsArg.adapter) {\n adapter = optionsArg.adapter\n\n // Note:\n // - `getConfig(..).datasources[0].provider` can be `postgresql`, `postgres`, `mysql`, or other known providers\n // - `getConfig(..).datasources[0].activeProvider`, stored in `config.activeProvider`, can be `postgresql`, `mysql`, or other known providers\n // - `adapter.provider` can be `postgres`, `mysql`, or `sqlite`, and changing this requires changes to Rust as well,\n // see https://github.com/prisma/prisma-engines/blob/d116c37d7d27aee74fdd840fc85ab2b45407e5ce/query-engine/driver-adapters/src/types.rs#L22-L23.\n //\n // TODO: Normalize these provider names once and for all in Prisma 6.\n const expectedDriverAdapterProvider =\n config.activeProvider === 'postgresql'\n ? 'postgres'\n : // CockroachDB is only accessible through Postgres driver adapters\n config.activeProvider === 'cockroachdb'\n ? 'postgres'\n : config.activeProvider\n\n if (adapter.provider !== expectedDriverAdapterProvider) {\n throw new PrismaClientInitializationError(\n `The Driver Adapter \\`${adapter.adapterName}\\`, based on \\`${adapter.provider}\\`, is not compatible with the provider \\`${expectedDriverAdapterProvider}\\` specified in the Prisma schema.`,\n this._clientVersion,\n )\n }\n }\n\n try {\n const options: PrismaClientOptions = optionsArg ?? {}\n const internal = options.__internal ?? {}\n\n const useDebug = internal.debug === true\n if (useDebug) {\n Debug.enable('prisma:client')\n }\n\n if (options.errorFormat) {\n this._errorFormat = options.errorFormat\n } else if (process.env.NODE_ENV === 'production') {\n this._errorFormat = 'minimal'\n } else if (process.env.NO_COLOR) {\n this._errorFormat = 'colorless'\n } else {\n this._errorFormat = 'colorless' // default errorFormat\n }\n\n this._runtimeDataModel = config.runtimeDataModel\n\n this._engineConfig = {\n enableDebugLogs: useDebug,\n logLevel: options.log && (getLogLevel(options.log) as any), // TODO\n logQueries:\n options.log &&\n Boolean(\n typeof options.log === 'string'\n ? options.log === 'query'\n : options.log.find((o) => (typeof o === 'string' ? o === 'query' : o.level === 'query')),\n ),\n compilerWasm: config.compilerWasm,\n clientVersion: config.clientVersion,\n previewFeatures: this._previewFeatures,\n activeProvider: config.activeProvider,\n inlineSchema: config.inlineSchema,\n tracingHelper: this._tracingHelper,\n transactionOptions: {\n maxWait: options.transactionOptions?.maxWait ?? 2000,\n timeout: options.transactionOptions?.timeout ?? 5000,\n isolationLevel: options.transactionOptions?.isolationLevel,\n },\n logEmitter,\n adapter,\n accelerateUrl: options.accelerateUrl,\n sqlCommenters: options.comments,\n parameterizationSchema: config.parameterizationSchema,\n runtimeDataModel: config.runtimeDataModel,\n }\n\n // Used in <https://github.com/prisma/prisma-extension-accelerate/blob/b6ffa853f038780f5ab2fc01bff584ca251f645b/src/extension.ts#L514>\n this._accelerateEngineConfig = Object.create(this._engineConfig)\n this._accelerateEngineConfig.accelerateUtils = {\n resolveDatasourceUrl: () => {\n if (options.accelerateUrl) {\n return options.accelerateUrl\n }\n throw new PrismaClientInitializationError(\n `\\\n\\`accelerateUrl\\` is required when using \\`@prisma/extension-accelerate\\`:\n\nnew PrismaClient({\n accelerateUrl: \"prisma://...\",\n}).$extends(withAccelerate())\n`,\n config.clientVersion,\n )\n },\n }\n\n debug('clientVersion', config.clientVersion)\n\n this._engine = getEngineInstance(this._engineConfig)\n this._requestHandler = new RequestHandler(this, logEmitter)\n\n if (options.log) {\n for (const log of options.log) {\n const level = typeof log === 'string' ? log : log.emit === 'stdout' ? log.level : null\n if (level) {\n this.$on(level, (event) => {\n logger.log(`${logger.tags[level] ?? ''}`, (event as LogEvent).message || (event as QueryEvent).query)\n })\n }\n }\n }\n } catch (e: any) {\n e.clientVersion = this._clientVersion\n throw e\n }\n\n // the first client has no parent so it is its own parent client\n // this is used for extensions to reference their parent client\n return (this._appliedParent = applyModelsAndClientExtensions(this))\n // this applied client is also a custom constructor return value\n }\n\n get [Symbol.toStringTag]() {\n return 'PrismaClient'\n }\n\n $on<E extends ExtendedEventType>(eventType: E, callback: EventCallback<E>): PrismaClient {\n if (eventType === 'beforeExit') {\n this._engine.onBeforeExit(callback as EventCallback<'beforeExit'>)\n } else if (eventType) {\n this._engineConfig.logEmitter.on(eventType, callback as EventCallback<LogLevel>)\n }\n return this\n }\n\n $connect() {\n try {\n return this._engine.start()\n } catch (e: any) {\n e.clientVersion = this._clientVersion\n throw e\n }\n }\n\n /**\n * Disconnect from the database\n */\n async $disconnect() {\n try {\n await this._engine.stop()\n } catch (e: any) {\n e.clientVersion = this._clientVersion\n throw e\n } finally {\n // Debug module keeps a list of last 100 logs regardless of environment\n // variables. This can cause a memory leak. It's especially bad in jest\n // environment where keeping an error in this list prevents jest sandbox\n // from being GCed. Clearing logs on disconnect helps to avoid that\n clearLogs()\n }\n }\n\n /**\n * Executes a raw query and always returns a number\n */\n $executeRawInternal(\n transaction: PrismaPromiseTransaction | undefined,\n clientMethod: string,\n args: RawQueryArgs,\n middlewareArgsMapper?: MiddlewareArgsMapper<unknown, unknown>,\n ): Promise<number> {\n const activeProvider = this._activeProvider\n\n return this._request({\n action: 'executeRaw',\n args,\n transaction,\n clientMethod,\n argsMapper: rawQueryArgsMapper({ clientMethod, activeProvider }),\n callsite: getCallSite(this._errorFormat),\n dataPath: [],\n middlewareArgsMapper,\n })\n }\n\n /**\n * Executes a raw query provided through a safe tag function\n * @see https://github.com/prisma/prisma/issues/7142\n *\n * @param query\n * @param values\n * @returns\n */\n $executeRaw(query: TemplateStringsArray | Sql, ...values: any[]) {\n return this._createPrismaPromise((transaction) => {\n if ((query as TemplateStringsArray).raw !== undefined || (query as Sql).sql !== undefined) {\n const [sql, argsMapper] = toSql(query, values)\n checkAlter(\n this._activeProvider,\n sql.text,\n sql.values,\n Array.isArray(query) ? 'prisma.$executeRaw`<SQL>`' : 'prisma.$executeRaw(sql`<SQL>`)',\n )\n return this.$executeRawInternal(transaction, '$executeRaw', sql, argsMapper)\n }\n\n throw new PrismaClientValidationError(\n `\\`$executeRaw\\` is a tag function, please use it like the following:\n\\`\\`\\`\nconst result = await prisma.$executeRaw\\`UPDATE User SET cool = \\${true} WHERE email = \\${'user@email.com'};\\`\n\\`\\`\\`\n\nOr read our docs at https://www.prisma.io/docs/concepts/components/prisma-client/raw-database-access#executeraw\n`,\n { clientVersion: this._clientVersion },\n )\n })\n }\n\n /**\n * Unsafe counterpart of `$executeRaw` that is susceptible to SQL injections\n * @see https://github.com/prisma/prisma/issues/7142\n *\n * @param query\n * @param values\n * @returns\n */\n $executeRawUnsafe(query: string, ...values: RawValue[]) {\n return this._createPrismaPromise((transaction) => {\n checkAlter(this._activeProvider, query, values, 'prisma.$executeRawUnsafe(<SQL>, [...values])')\n return this.$executeRawInternal(transaction, '$executeRawUnsafe', [query, ...values])\n })\n }\n\n /**\n * Executes a raw command only for MongoDB\n *\n * @param command\n * @returns\n */\n $runCommandRaw(command: Record<string, JsInputValue>) {\n if (config.activeProvider !== 'mongodb') {\n throw new PrismaClientValidationError(\n `The ${config.activeProvider} provider does not support $runCommandRaw. Use the mongodb provider.`,\n { clientVersion: this._clientVersion },\n )\n }\n\n return this._createPrismaPromise((transaction) => {\n return this._request({\n args: command,\n clientMethod: '$runCommandRaw',\n dataPath: [],\n action: 'runCommandRaw',\n argsMapper: rawCommandArgsMapper,\n callsite: getCallSite(this._errorFormat),\n transaction: transaction,\n })\n })\n }\n\n /**\n * Executes a raw query and returns selected data\n */\n async $queryRawInternal(\n transaction: PrismaPromiseTransaction | undefined,\n clientMethod: string,\n args: RawQueryArgs,\n middlewareArgsMapper?: MiddlewareArgsMapper<unknown, unknown>,\n ) {\n const activeProvider = this._activeProvider\n\n return this._request({\n action: 'queryRaw',\n args,\n transaction,\n clientMethod,\n argsMapper: rawQueryArgsMapper({ clientMethod, activeProvider }),\n callsite: getCallSite(this._errorFormat),\n dataPath: [],\n middlewareArgsMapper,\n })\n }\n\n /**\n * Executes a raw query provided through a safe tag function\n * @see https://github.com/prisma/prisma/issues/7142\n *\n * @param query\n * @param values\n * @returns\n */\n $queryRaw(query: TemplateStringsArray | Sql, ...values: any[]) {\n return this._createPrismaPromise((transaction) => {\n if ((query as TemplateStringsArray).raw !== undefined || (query as Sql).sql !== undefined) {\n return this.$queryRawInternal(transaction, '$queryRaw', ...toSql(query, values))\n }\n\n throw new PrismaClientValidationError(\n `\\`$queryRaw\\` is a tag function, please use it like the following:\n\\`\\`\\`\nconst result = await prisma.$queryRaw\\`SELECT * FROM User WHERE id = \\${1} OR email = \\${'user@email.com'};\\`\n\\`\\`\\`\n\nOr read our docs at https://www.prisma.io/docs/concepts/components/prisma-client/raw-database-access#queryraw\n`,\n { clientVersion: this._clientVersion },\n )\n })\n }\n\n /**\n * Counterpart to $queryRaw, that returns strongly typed results\n * @param typedSql\n */\n $queryRawTyped(typedSql: UnknownTypedSql) {\n return this._createPrismaPromise((transaction) => {\n if (!this._hasPreviewFlag('typedSql')) {\n throw new PrismaClientValidationError(\n '`typedSql` preview feature must be enabled in order to access $queryRawTyped API',\n { clientVersion: this._clientVersion },\n )\n }\n return this.$queryRawInternal(transaction, '$queryRawTyped', typedSql)\n })\n }\n\n /**\n * Unsafe counterpart of `$queryRaw` that is susceptible to SQL injections\n * @see https://github.com/prisma/prisma/issues/7142\n *\n * @param query\n * @param values\n * @returns\n */\n $queryRawUnsafe(query: string, ...values: RawValue[]) {\n return this._createPrismaPromise((transaction) => {\n return this.$queryRawInternal(transaction, '$queryRawUnsafe', [query, ...values])\n })\n }\n\n /**\n * Execute a batch of requests in a transaction\n * @param requests\n * @param options\n */\n _transactionWithArray({\n promises,\n options,\n }: {\n promises: Array<PrismaPromise<any>>\n options?: BatchTransactionOptions\n }): Promise<any> {\n const id = BatchTxIdCounter.nextId()\n const lock = getLockCountPromise(promises.length)\n\n const requests = promises.map((request, index) => {\n if (request?.[Symbol.toStringTag] !== 'PrismaPromise') {\n throw new Error(\n `All elements of the array need to be Prisma Client promises. Hint: Please make sure you are not awaiting the Prisma client calls you intended to pass in the $transaction function.`,\n )\n }\n\n const isolationLevel = options?.isolationLevel ?? this._engineConfig.transactionOptions.isolationLevel\n const transaction = { kind: 'batch', id, index, isolationLevel, lock } as const\n return request.requestTransaction?.(transaction) ?? request\n })\n\n return waitForBatch(requests)\n }\n\n /**\n * Perform a long-running transaction\n * @param callback\n * @param options\n * @returns\n */\n async _transactionWithCallback({\n callback,\n options,\n }: {\n callback: (client: Client) => Promise<unknown>\n options?: Options\n }) {\n const headers = { traceparent: this._tracingHelper.getTraceParent() }\n\n const optionsWithDefaults: Options = {\n maxWait: options?.maxWait ?? this._engineConfig.transactionOptions.maxWait,\n timeout: options?.timeout ?? this._engineConfig.transactionOptions.timeout,\n isolationLevel: options?.isolationLevel ?? this._engineConfig.transactionOptions.isolationLevel,\n }\n const info = await this._engine.transaction('start', headers, optionsWithDefaults)\n\n let result: unknown\n try {\n // execute user logic with a proxied the client\n const transaction = { kind: 'itx', ...info } as const\n\n result = await callback(this._createItxClient(transaction))\n\n // it went well, then we commit the transaction\n await this._engine.transaction('commit', headers, info)\n } catch (e: any) {\n // it went bad, then we rollback the transaction\n await this._engine.transaction('rollback', headers, info).catch(() => {})\n\n throw e // silent rollback, throw original error\n }\n\n return result\n }\n\n _createItxClient(transaction: PrismaPromiseInteractiveTransaction): Client {\n return createCompositeProxy(\n applyModelsAndClientExtensions(\n createCompositeProxy(unApplyModelsAndClientExtensions(this), [\n addProperty('_appliedParent', () => this._appliedParent._createItxClient(transaction)),\n addProperty('_createPrismaPromise', () => createPrismaPromiseFactory(transaction)),\n addProperty(TX_ID, () => transaction.id),\n ]),\n ),\n [removeProperties(itxClientDenyList)],\n )\n }\n\n /**\n * Execute queries within a transaction\n * @param input a callback or a query list\n * @param options to set timeouts (callback)\n * @returns\n */\n $transaction(input: any, options?: any) {\n let callback: () => Promise<any>\n\n // iTx - Interactive transaction\n if (typeof input === 'function') {\n if (this._engineConfig.adapter?.adapterName === '@prisma/adapter-d1') {\n callback = () => {\n throw new Error(\n 'Cloudflare D1 does not support interactive transactions. We recommend you to refactor your queries with that limitation in mind, and use batch transactions with `prisma.$transactions([])` where applicable.',\n )\n }\n } else {\n callback = () => this._transactionWithCallback({ callback: input, options })\n }\n } else {\n // Batch transaction\n callback = () => this._transactionWithArray({ promises: input, options })\n }\n\n const spanOptions = {\n name: 'transaction',\n attributes: { method: '$transaction' },\n }\n\n return this._tracingHelper.runInChildSpan(spanOptions, callback)\n }\n\n /**\n * Runs the middlewares over params before executing a request\n * @param internalParams\n * @returns\n */\n _request(internalParams: InternalRequestParams): Promise<any> {\n // this is the otel context that is active at the callsite\n internalParams.otelParentCtx = this._tracingHelper.getActiveContext()\n const middlewareArgsMapper = internalParams.middlewareArgsMapper ?? noopMiddlewareArgsMapper\n\n // make sure that we don't leak extra properties to users\n const params: QueryMiddlewareParams = {\n args: middlewareArgsMapper.requestArgsToMiddlewareArgs(internalParams.args),\n dataPath: internalParams.dataPath,\n runInTransaction: Boolean(internalParams.transaction),\n action: internalParams.action,\n model: internalParams.model,\n }\n\n // span options for opentelemetry instrumentation\n const spanOptions = {\n operation: {\n name: 'operation',\n attributes: {\n method: params.action,\n model: params.model,\n name: params.model ? `${params.model}.${params.action}` : params.action,\n },\n } as ExtendedSpanOptions,\n }\n\n // prepare recursive fn that will pipe params through middlewares\n const consumer = async (changedMiddlewareParams: QueryMiddlewareParams) => {\n // we proceed with request execution\n // before we send the execution request, we use the changed params\n const { runInTransaction, args, ...changedRequestParams } = changedMiddlewareParams\n const requestParams = {\n ...internalParams,\n ...changedRequestParams,\n }\n\n if (args) {\n requestParams.args = middlewareArgsMapper.middlewareArgsToRequestArgs(args)\n }\n\n // if middleware switched off `runInTransaction`, unset `transaction`\n // property on request as well so it will be executed outside of the tx\n if (internalParams.transaction !== undefined && runInTransaction === false) {\n delete requestParams.transaction // client extensions check for this\n }\n\n const result = await applyQueryExtensions(this, requestParams) // also executes the query\n if (!requestParams.model) {\n return result\n }\n return applyAllResultExtensions({\n result,\n modelName: requestParams.model,\n args: requestParams.args,\n extensions: this._extensions,\n runtimeDataModel: this._runtimeDataModel,\n globalOmit: this._globalOmit,\n })\n }\n\n return this._tracingHelper.runInChildSpan(spanOptions.operation, () => {\n if (NODE_CLIENT) {\n // https://github.com/prisma/prisma/issues/3148 not for edge client\n const asyncRes = new AsyncResource('prisma-client-request')\n return asyncRes.runInAsyncScope(() => consumer(params))\n }\n\n return consumer(params)\n })\n }\n\n async _executeRequest({\n args,\n clientMethod,\n dataPath,\n callsite,\n action,\n model,\n argsMapper,\n transaction,\n unpacker,\n otelParentCtx,\n customDataProxyFetch,\n }: InternalRequestParams) {\n try {\n // execute argument transformation before execution\n args = argsMapper ? argsMapper(args) : args\n\n const spanOptions: ExtendedSpanOptions = {\n name: 'serialize',\n }\n\n const message = this._tracingHelper.runInChildSpan(spanOptions, () =>\n serializeJsonQuery({\n modelName: model,\n runtimeDataModel: this._runtimeDataModel,\n action,\n args,\n clientMethod,\n callsite,\n extensions: this._extensions,\n errorFormat: this._errorFormat,\n clientVersion: this._clientVersion,\n previewFeatures: this._previewFeatures,\n globalOmit: this._globalOmit,\n }),\n )\n\n // as prettyPrintArguments takes a bit of compute\n // we only want to do it, if debug is enabled for 'prisma-client'\n if (Debug.enabled('prisma:client')) {\n debug(`Prisma Client call:`)\n debug(`prisma.${clientMethod}(${prettyPrintArguments(args)})`)\n debug(`Generated request:`)\n debug(JSON.stringify(message, null, 2) + '\\n')\n }\n\n if (transaction?.kind === 'batch') {\n /** @see {@link getLockCountPromise} */\n await transaction.lock\n }\n\n return this._requestHandler.request({\n protocolQuery: message,\n modelName: model,\n action,\n clientMethod,\n dataPath,\n callsite,\n args,\n extensions: this._extensions,\n transaction,\n unpacker,\n otelParentCtx,\n otelChildCtx: this._tracingHelper.getActiveContext(),\n globalOmit: this._globalOmit,\n customDataProxyFetch,\n })\n } catch (e) {\n e.clientVersion = this._clientVersion\n throw e\n }\n }\n\n /**\n * Shortcut for checking a preview flag\n * @param feature preview flag\n * @returns\n */\n _hasPreviewFlag(feature: string) {\n return !!this._engineConfig.previewFeatures?.includes(feature)\n }\n\n $extends = $extends\n }\n\n return PrismaClient\n}\n\nfunction toSql(query: TemplateStringsArray | Sql, values: unknown[]): [Sql, MiddlewareArgsMapper<unknown, unknown>] {\n if (isTemplateStringArray(query)) {\n return [new Sql(query, values), templateStringMiddlewareArgsMapper]\n }\n\n return [query, sqlMiddlewareArgsMapper]\n}\n\nfunction isTemplateStringArray(value: unknown): value is TemplateStringsArray {\n return Array.isArray(value) && Array.isArray(value['raw'])\n}\n", "import type { CompositeProxyLayer } from './createCompositeProxy'\n\n/**\n * Composite proxy layer that forwards all reads\n * to provided object\n *\n * @param object\n * @returns\n */\nexport function addObjectProperties(object: object): CompositeProxyLayer {\n return {\n getKeys() {\n return Object.keys(object)\n },\n\n getPropertyValue(key) {\n return object[key]\n },\n }\n}\n", "import { CompositeProxyLayer } from './createCompositeProxy'\n\n/**\n * Composite proxy layer, that adds a single property to the target\n * @param key the name of the property\n * @param factory the function that returns the value of the property\n * @returns\n */\nexport function addProperty(key: string | symbol, factory: () => unknown): CompositeProxyLayer {\n return {\n getKeys() {\n return [key]\n },\n\n getPropertyValue() {\n return factory()\n },\n }\n}\n", "import { Cache } from '@prisma/client-common'\n\nimport { CompositeProxyLayer } from './createCompositeProxy'\n\n/**\n * Composite proxy layer that adds caching to another\n * layer.\n *\n * @param baseLayer\n * @returns\n */\nexport function cacheProperties<KeyType extends string | symbol>(\n baseLayer: CompositeProxyLayer<KeyType>,\n): CompositeProxyLayer<KeyType> {\n const cache = new Cache<KeyType, unknown>()\n return {\n getKeys() {\n return baseLayer.getKeys()\n },\n\n getPropertyValue(key) {\n return cache.getOrCreate(key, () => baseLayer.getPropertyValue(key))\n },\n\n getPropertyDescriptor(key) {\n return baseLayer.getPropertyDescriptor?.(key)\n },\n }\n}\n", "export const defaultPropertyDescriptor = {\n enumerable: true,\n configurable: true,\n writable: true,\n}\n\nexport function defaultProxyHandlers<T extends object>(ownKeys: (string | symbol)[]) {\n const _ownKeys = new Set(ownKeys)\n return {\n getPrototypeOf: () => Object.prototype,\n getOwnPropertyDescriptor: () => defaultPropertyDescriptor,\n has: (target: T, prop: string | symbol) => _ownKeys.has(prop),\n set: (target: T, prop: string | symbol, value: any) => {\n return _ownKeys.add(prop) && Reflect.set(target, prop, value)\n },\n ownKeys: () => [..._ownKeys],\n } as const\n}\n", "import { defaultPropertyDescriptor } from '../model/utils/defaultProxyHandlers'\n\nexport interface CompositeProxyLayer<KeyType extends string | symbol = string | symbol> {\n /**\n * Returns a list of keys, defined by a layer\n */\n getKeys(): ReadonlyArray<KeyType>\n\n /**\n * Returns a value for a property for a given key (one of the keys, returned\n * from `getKeys`)\n * @param key\n */\n getPropertyValue(key: KeyType): unknown\n\n /**\n * Gets a descriptor for given property. If not implemented or undefined is returned, { enumerable: true, writeable: true, configurable: true} is defaulted\n * is used\n * @param key\n */\n getPropertyDescriptor?(key: KeyType): PropertyDescriptor | undefined\n\n /**\n * Allows to override results for hasOwnProperty/in operator. If not implemented, returns true\n * @param key\n */\n has?(key: KeyType): boolean\n}\n\nconst customInspect = Symbol.for('nodejs.util.inspect.custom')\n\n/**\n * Creates a proxy from a set of layers.\n * Each layer is a building for a proxy (potentially, reusable) that\n * can add or override property on top of the target.\n * When multiple layers define the same property, last one wins\n *\n * @param target\n * @param layers\n * @returns\n */\nexport function createCompositeProxy<T extends object>(target: T, layers: CompositeProxyLayer[]): T {\n const keysToLayerMap = mapKeysToLayers(layers)\n const overwrittenKeys = new Set<string | symbol>()\n\n const proxy = new Proxy(target, {\n get(target, prop) {\n // explicit overwrites of a property have highest priority\n if (overwrittenKeys.has(prop)) {\n return target[prop]\n }\n\n // next, we see if property is defined in one of the layers\n const layer = keysToLayerMap.get(prop)\n if (layer) {\n return layer.getPropertyValue(prop)\n }\n\n // finally, we read a prop from target\n return target[prop]\n },\n\n has(target, prop) {\n if (overwrittenKeys.has(prop)) {\n return true\n }\n const layer = keysToLayerMap.get(prop)\n if (layer) {\n return layer.has?.(prop) ?? true\n }\n\n return Reflect.has(target, prop)\n },\n\n ownKeys(target) {\n const targetKeys = getExistingKeys(Reflect.ownKeys(target), keysToLayerMap)\n const layerKeys = getExistingKeys(Array.from(keysToLayerMap.keys()), keysToLayerMap)\n return [...new Set([...targetKeys, ...layerKeys, ...overwrittenKeys])]\n },\n\n set(target, prop, value) {\n const layer = keysToLayerMap.get(prop)\n if (layer?.getPropertyDescriptor?.(prop)?.writable === false) {\n return false\n }\n overwrittenKeys.add(prop)\n return Reflect.set(target, prop, value)\n },\n\n getOwnPropertyDescriptor(target, prop) {\n const original = Reflect.getOwnPropertyDescriptor(target, prop)\n if (original && !original.configurable) {\n // non-configurable properties can not change descriptors\n return original\n }\n\n const layer = keysToLayerMap.get(prop)\n if (layer) {\n if (layer.getPropertyDescriptor) {\n return {\n ...defaultPropertyDescriptor,\n ...layer?.getPropertyDescriptor(prop),\n }\n }\n return defaultPropertyDescriptor\n }\n\n return original\n },\n\n defineProperty(target, property, attributes) {\n overwrittenKeys.add(property)\n return Reflect.defineProperty(target, property, attributes)\n },\n\n getPrototypeOf: () => Object.prototype,\n })\n\n proxy[customInspect] = function () {\n // Default node.js console.log and util.inspect deliberately avoid triggering any proxy traps and log\n // original target. This is not we want for our usecases: we want console.log to output the result as if\n // the properties actually existed on the target. Using spread operator forces us to produce correct object\n const toLog = { ...this }\n delete toLog[customInspect]\n return toLog\n }\n return proxy\n}\n\nfunction mapKeysToLayers(layers: CompositeProxyLayer[]) {\n const keysToLayerMap = new Map<string | symbol, CompositeProxyLayer>()\n for (const layer of layers) {\n const keys = layer.getKeys()\n for (const key of keys) {\n keysToLayerMap.set(key, layer)\n }\n }\n return keysToLayerMap\n}\n\nfunction getExistingKeys(keys: Array<string | symbol>, keysToLayerMap: Map<string | symbol, CompositeProxyLayer>) {\n return keys.filter((key) => {\n const layer = keysToLayerMap.get(key)\n return layer?.has?.(key) ?? true\n })\n}\n", "import { CompositeProxyLayer } from './createCompositeProxy'\n\nexport function removeProperties(keys: ReadonlyArray<string | symbol>): CompositeProxyLayer {\n return {\n getKeys() {\n return keys\n },\n\n has() {\n return false\n },\n\n getPropertyValue() {\n return undefined\n },\n }\n}\n", "import { Writer } from '@prisma/ts-builders'\n\nimport { JsArgs } from '../types/exported/JsApi'\nimport { buildArgumentsRenderingTree } from './ArgumentsRenderingTree'\nimport { inactiveColors } from './base'\n\nexport function prettyPrintArguments(args?: JsArgs): string {\n if (args === undefined) {\n return ''\n }\n const tree = buildArgumentsRenderingTree(args)\n const writer = new Writer(0, { colors: inactiveColors })\n return writer.write(tree).toString()\n}\n", "var UNKNOWN_FUNCTION = '<unknown>';\n/**\n * This parses the different stack traces and puts them into one format\n * This borrows heavily from TraceKit (https://github.com/csnover/TraceKit)\n */\n\nfunction parse(stackString) {\n var lines = stackString.split('\\n');\n return lines.reduce(function (stack, line) {\n var parseResult = parseChrome(line) || parseWinjs(line) || parseGecko(line) || parseNode(line) || parseJSC(line);\n\n if (parseResult) {\n stack.push(parseResult);\n }\n\n return stack;\n }, []);\n}\nvar chromeRe = /^\\s*at (.*?) ?\\(((?:file|https?|blob|chrome-extension|native|eval|webpack|rsc|<anonymous>|\\/|[a-z]:\\\\|\\\\\\\\).*?)(?::(\\d+))?(?::(\\d+))?\\)?\\s*$/i;\nvar chromeEvalRe = /\\((\\S*)(?::(\\d+))(?::(\\d+))\\)/;\n\nfunction parseChrome(line) {\n var parts = chromeRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n var isNative = parts[2] && parts[2].indexOf('native') === 0; // start of line\n\n var isEval = parts[2] && parts[2].indexOf('eval') === 0; // start of line\n\n var submatch = chromeEvalRe.exec(parts[2]);\n\n if (isEval && submatch != null) {\n // throw out eval line/column and use top-most line/column number\n parts[2] = submatch[1]; // url\n\n parts[3] = submatch[2]; // line\n\n parts[4] = submatch[3]; // column\n }\n\n return {\n file: !isNative ? parts[2] : null,\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: isNative ? [parts[2]] : [],\n lineNumber: parts[3] ? +parts[3] : null,\n column: parts[4] ? +parts[4] : null\n };\n}\n\nvar winjsRe = /^\\s*at (?:((?:\\[object object\\])?.+) )?\\(?((?:file|ms-appx|https?|webpack|rsc|blob):.*?):(\\d+)(?::(\\d+))?\\)?\\s*$/i;\n\nfunction parseWinjs(line) {\n var parts = winjsRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n return {\n file: parts[2],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: [],\n lineNumber: +parts[3],\n column: parts[4] ? +parts[4] : null\n };\n}\n\nvar geckoRe = /^\\s*(.*?)(?:\\((.*?)\\))?(?:^|@)((?:file|https?|blob|chrome|webpack|rsc|resource|\\[native).*?|[^@]*bundle)(?::(\\d+))?(?::(\\d+))?\\s*$/i;\nvar geckoEvalRe = /(\\S+) line (\\d+)(?: > eval line \\d+)* > eval/i;\n\nfunction parseGecko(line) {\n var parts = geckoRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n var isEval = parts[3] && parts[3].indexOf(' > eval') > -1;\n var submatch = geckoEvalRe.exec(parts[3]);\n\n if (isEval && submatch != null) {\n // throw out eval line/column and use top-most line number\n parts[3] = submatch[1];\n parts[4] = submatch[2];\n parts[5] = null; // no column when eval\n }\n\n return {\n file: parts[3],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: parts[2] ? parts[2].split(',') : [],\n lineNumber: parts[4] ? +parts[4] : null,\n column: parts[5] ? +parts[5] : null\n };\n}\n\nvar javaScriptCoreRe = /^\\s*(?:([^@]*)(?:\\((.*?)\\))?@)?(\\S.*?):(\\d+)(?::(\\d+))?\\s*$/i;\n\nfunction parseJSC(line) {\n var parts = javaScriptCoreRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n return {\n file: parts[3],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: [],\n lineNumber: +parts[4],\n column: parts[5] ? +parts[5] : null\n };\n}\n\nvar nodeRe = /^\\s*at (?:((?:\\[object object\\])?[^\\\\/]+(?: \\[as \\S+\\])?) )?\\(?(.*?):(\\d+)(?::(\\d+))?\\)?\\s*$/i;\n\nfunction parseNode(line) {\n var parts = nodeRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n return {\n file: parts[2],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: [],\n lineNumber: +parts[3],\n column: parts[4] ? +parts[4] : null\n };\n}\n\nexport { parse };\n", "import { pathToPosix } from '@prisma/internals'\nimport * as stackTraceParser from 'stacktrace-parser'\n\nimport { ErrorFormat } from '../getPrismaClient'\n\ndeclare global {\n /**\n * a global variable that is injected by us via jest to make our snapshots\n * work in clients that cannot read from disk (e.g. wasm or edge clients)\n */\n let $EnabledCallSite: typeof EnabledCallSite | undefined\n}\n\nexport type LocationInFile = {\n fileName: string\n lineNumber: number | null\n columnNumber: number | null\n}\n\nexport interface CallSite {\n getLocation(): LocationInFile | null\n}\n\nclass DisabledCallSite implements CallSite {\n getLocation(): LocationInFile | null {\n return null\n }\n}\n\nexport class EnabledCallSite implements CallSite {\n private _error: Error\n constructor() {\n this._error = new Error()\n }\n getLocation(): LocationInFile | null {\n const stack = this._error.stack\n if (!stack) {\n return null\n }\n const stackFrames = stackTraceParser.parse(stack)\n // TODO: more resilient logic to check that it's not relative to cwd\n const frame = stackFrames.find((t) => {\n // Here we are trying to find the location in the user's code which caused the error\n if (!t.file) {\n return false\n }\n\n // convert windows path to posix path\n const posixFile = pathToPosix(t.file)\n return (\n posixFile !== '<anonymous>' && // Ignore as we can not read an <anonymous> file\n !posixFile.includes('@prisma') && // Internal, unbundled code\n !posixFile.includes('/packages/client/src/runtime/') && // Runtime sources when source maps are used\n !posixFile.endsWith('/runtime/client.js') && // Bundled runtimes\n !posixFile.startsWith('internal/') && // We don't want internal nodejs files\n !t.methodName.includes('new ') && // \"new CallSite\" call and maybe other constructors\n !t.methodName.includes('getCallSite') && // getCallSite function from this module\n !t.methodName.includes('Proxy.') && // Model proxies\n t.methodName.split('.').length < 4\n )\n })\n\n if (!frame || !frame.file) {\n return null\n }\n\n return {\n fileName: frame.file,\n lineNumber: frame.lineNumber,\n columnNumber: frame.column,\n }\n }\n}\n\nexport function getCallSite(errorFormat: ErrorFormat): CallSite {\n if (errorFormat === 'minimal' || TARGET_BUILD_TYPE === 'wasm-compiler-edge') {\n if (typeof $EnabledCallSite === 'function' && errorFormat !== 'minimal') {\n return new $EnabledCallSite()\n } else {\n return new DisabledCallSite()\n }\n } else {\n return new EnabledCallSite()\n }\n}\n", "export const aggregateMap = {\n _avg: true,\n _count: true,\n _sum: true,\n _min: true,\n _max: true,\n}\n", "import type { UserArgs } from '../../request/UserArgs'\nimport type { ModelAction } from '../applyModel'\nimport { aggregateMap } from './utils/aggregateMap'\n\n/**\n * Transforms the `userArgs` for the `.aggregate` shorthand. It is an API sugar\n * for not having to do things like: `{select: {_avg: {select: {age: true}}}}`.\n * The goal here is to desugar it into something that is understood by the QE.\n * @param args to transform\n * @returns\n */\nexport function desugarUserArgs(args: UserArgs = {}) {\n const _args = desugarCountInUserArgs(args)\n const userArgsEntries = Object.entries(_args)\n\n return userArgsEntries.reduce(\n (aggregateArgs, [key, value]) => {\n if (aggregateMap[key] !== undefined) {\n // if it's an aggregate, we re-wrap into select\n aggregateArgs['select']![key] = { select: value }\n } else {\n aggregateArgs[key] = value // or leave it alone\n }\n\n return aggregateArgs\n },\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n { select: {} } as UserArgs & { select: UserArgs },\n )\n}\n\n/**\n * Desugar `userArgs` when it contains `{_count: true}`.\n * @param args the user input\n * @returns\n */\nfunction desugarCountInUserArgs(args: UserArgs = {}) {\n if (typeof args['_count'] === 'boolean') {\n return { ...args, _count: { _all: args['_count'] } }\n }\n\n return args\n}\n\n/**\n * Creates an unpacker that adds sugar to the basic result of the QE. An\n * unpacker helps to transform a result before returning it to the user.\n * @param args the user input\n * @returns\n */\nexport function createUnpacker(args: UserArgs = {}) {\n return (data: object) => {\n if (typeof args['_count'] === 'boolean') {\n data['_count'] = data['_count']['_all']\n }\n\n return data\n }\n}\n\n/**\n * Executes the `.aggregate` action on a model.\n * @see {desugarUserArgs}\n * @param args the user input to desugar\n * @param modelAction a callback action that triggers request execution\n * @returns\n */\nexport function aggregate(args: UserArgs, modelAction: ModelAction) {\n const aggregateUnpacker = createUnpacker(args)\n\n return modelAction({\n action: 'aggregate',\n unpacker: aggregateUnpacker,\n argsMapper: desugarUserArgs,\n })(args)\n}\n", "import type { UserArgs } from '../../request/UserArgs'\nimport type { ModelAction } from '../applyModel'\nimport { createUnpacker as createUnpackerAggregate, desugarUserArgs as desugarUserArgsAggregate } from './aggregate'\n\n/**\n * Transforms the `userArgs` for the `.count` shorthand. It is an API sugar. It\n * reuses the logic from the `.aggregate` shorthand to add additional handling.\n * The goal here is to desugar it into something that is understood by the QE.\n * @param args to transform\n * @returns\n */\nfunction desugarUserArgs(args: UserArgs = {}) {\n const { select, ..._args } = args // exclude select\n\n if (typeof select === 'object') {\n return desugarUserArgsAggregate({ ..._args, _count: select })\n } else {\n return desugarUserArgsAggregate({ ..._args, _count: { _all: true } })\n }\n}\n\n/**\n * Creates an unpacker that adds sugar to the basic result of the QE. An\n * unpacker helps to transform a result before returning it to the user.\n * @param args the user input\n * @returns\n */\nexport function createUnpacker(args: UserArgs = {}) {\n if (typeof args['select'] === 'object') {\n return (data: object) => createUnpackerAggregate(args)(data)['_count']\n } else {\n return (data: object) => createUnpackerAggregate(args)(data)['_count']['_all']\n }\n}\n\n/**\n * Executes the `.count` action on a model via {@link aggregate}.\n * @param args the user input to desugar\n * @param modelAction a callback action that triggers request execution\n * @returns\n */\nexport function count(args: UserArgs, modelAction: ModelAction) {\n return modelAction({\n action: 'count',\n unpacker: createUnpacker(args),\n argsMapper: desugarUserArgs,\n })(args)\n}\n", "import type { UserArgs } from '../../request/UserArgs'\nimport type { ModelAction } from '../applyModel'\nimport { desugarUserArgs as desugarUserArgsAggregate } from './aggregate'\n\n/**\n * Transforms the `userArgs` for the `.groupBy` shorthand. It is an API sugar.\n * It reuses the logic from the `.aggregate` shorthand and adds additional\n * handling for the `by` clause. The goal here is to desugar it into something\n * that is understood by the QE.\n * @param args to transform\n * @returns\n */\nfunction desugarUserArgs(args: UserArgs = {}) {\n const _args = desugarUserArgsAggregate(args)\n\n // we desugar the array into { [key]: boolean }\n if (Array.isArray(_args['by'])) {\n for (const key of _args['by']) {\n if (typeof key === 'string') {\n _args['select'][key] = true\n }\n }\n } else if (typeof _args['by'] === 'string') {\n _args['select'][_args['by']] = true\n }\n\n return _args\n}\n\n/**\n * Creates an unpacker that adds sugar to the basic result of the QE. An\n * unpacker helps to transform a result before returning it to the user.\n * @param args the user input\n * @returns\n */\nexport function createUnpacker(args: UserArgs = {}) {\n return (data: object[]) => {\n if (typeof args?.['_count'] === 'boolean') {\n data.forEach((row) => {\n row['_count'] = row['_count']['_all']\n })\n }\n\n return data\n }\n}\n\n/**\n * Executes the `.groupBy` action on a model by reusing {@link aggregate}.\n * @param args the user input to desugar\n * @param modelAction a callback action that triggers request execution\n * @returns\n */\nexport function groupBy(args: UserArgs, modelAction: ModelAction) {\n return modelAction({\n action: 'groupBy',\n unpacker: createUnpacker(args),\n argsMapper: desugarUserArgs,\n })(args)\n}\n", "import type { Client } from '../../getPrismaClient'\nimport type { UserArgs } from '../request/UserArgs'\nimport { Action } from '../types/exported/JsApi'\nimport { aggregate } from './aggregates/aggregate'\nimport { count } from './aggregates/count'\nimport { groupBy } from './aggregates/groupBy'\nimport type { ModelAction } from './applyModel'\n\n/**\n * Dynamically returns the appropriate aggregate action for a given `action`.\n * With this, we are able to provide an aggregate api that has a better DX. In\n * short, we manipulate the user input which is designed to have DX to transform\n * it into something that the engines understand. Similarly, we take the engine\n * output for that input and produce something that is easier to work with.\n * @param action that tells which aggregate action to execute\n * @param modelAction a callback action that triggers request execution\n * @returns\n */\nexport function applyAggregates(client: Client, action: Action, modelAction: ModelAction) {\n // we effectively take over the aggregate api to perform data changes\n if (action === 'aggregate') return (userArgs?: UserArgs) => aggregate(userArgs, modelAction)\n if (action === 'count') return (userArgs?: UserArgs) => count(userArgs, modelAction)\n if (action === 'groupBy') return (userArgs?: UserArgs) => groupBy(userArgs, modelAction)\n\n return undefined\n}\n", "import { keyBy, RuntimeModel } from '@prisma/client-common'\n\nimport { FieldRefImpl } from './FieldRef'\nimport { defaultProxyHandlers } from './utils/defaultProxyHandlers'\n\nexport type FieldProxy = {\n readonly [key: string]: FieldRefImpl<string, string>\n}\n\nexport function applyFieldsProxy(modelName: string, model: RuntimeModel): FieldProxy {\n const scalarFieldsList = model.fields.filter((field) => !field.relationName)\n const scalarFields = keyBy(scalarFieldsList, 'name')\n return new Proxy(\n {},\n {\n get(target, prop) {\n if (prop in target || typeof prop === 'symbol') {\n return target[prop]\n }\n const dmmfField = scalarFields[prop]\n if (dmmfField) {\n return new FieldRefImpl(modelName, prop, dmmfField.type, dmmfField.isList, dmmfField.kind === 'enum')\n }\n\n return undefined\n },\n ...defaultProxyHandlers(Object.keys(scalarFields)),\n },\n )\n}\n", "// Taken from https://gist.github.com/LukeChannings/15c92cef5a016a8b21a0\n\n// ensure the keys being passed is an array of key paths\n// example: 'a.b' becomes ['a', 'b'] unless it was already ['a', 'b']\nconst keys = (ks: string | string[]) => (Array.isArray(ks) ? ks : ks.split('.'))\n\n// traverse the set of keys left to right,\n// returning the current value in each iteration.\n// if at any point the value for the current key does not exist,\n// return the default value\nexport const deepGet = (o, kp: string[]) => keys(kp).reduce((o, k) => o && o[k], o)\n\n// traverse the set of keys right to left,\n// returning a new object containing both properties from the object\n// we were originally passed and our new property.\n//\n// Example:\n// If o = { a: { b: { c: 1 } } }\n//\n// deepSet(o, ['a', 'b', 'c'], 2) will progress thus:\n// 1. c = Object.assign({}, {c: 1}, { c: 2 })\n// 2. b = Object.assign({}, { b: { c: 1 } }, { b: c })\n// 3. returned = Object.assign({}, { a: { b: { c: 1 } } }, { a: b })\nexport const deepSet = (o: any, kp: string | string[], v: any) =>\n keys(kp).reduceRight((v, k, i, ks) => Object.assign({}, deepGet(o, ks.slice(0, i)), { [k]: v }), v)\n", "import type * as DMMF from '@prisma/dmmf'\n\nimport type { Client } from '../../getPrismaClient'\nimport { getCallSite } from '../../utils/CallSite'\nimport { deepSet } from '../../utils/deep-set'\nimport type { UserArgs } from '../request/UserArgs'\nimport type { ModelAction } from './applyModel'\nimport { defaultProxyHandlers } from './utils/defaultProxyHandlers'\n\n/**\n * The fluent API makes that nested relations can be retrieved at once. It's a\n * helper for writing `select` statements on relations with a chaining api.\n * Because of this, we automatically add `select` statements to the query, that\n * also means that we need to provide a `dataPath` for unpacking nested values.\n * @see {getNextUserArgs}\n * @param dmmfModelName\n * @param prevDataPath\n * @returns\n */\nfunction getNextDataPath(fluentPropName?: string, prevDataPath?: string[]) {\n if (fluentPropName === undefined || prevDataPath === undefined) return []\n\n return [...prevDataPath, 'select', fluentPropName]\n}\n\n/**\n * @see {getNextDataPath} for introduction. The goal of the fluent API is to\n * make it easy to retrieve nested relations. For this, we construct the query\n * args that are necessary to retrieve the nested relations. It consists of\n * nesting `select` statements each time that we access a relation.\n * @param callArgs usually passed on the last call of the chaining api\n * @param prevArgs when multiple chaining occurs, they are the previous\n * @param nextDataPath path where to set `callArgs` in `prevArgs`\n * @example\n * ```ts\n * prisma.user.findUnique().link().user()\n *\n * // will end up with an args like this:\n * // args {\n * // \"where\": {\n * // \"email\": \"1639498523518@gmail.com\"\n * // },\n * // \"select\": {\n * // \"link\": {\n * // \"select\": {\n * // \"user\": true\n * // }\n * // }\n * // }\n * // }\n * ```\n */\nfunction getNextUserArgs(callArgs: UserArgs, prevArgs: UserArgs, nextDataPath: string[]): UserArgs {\n if (prevArgs === undefined) return callArgs ?? {}\n\n return deepSet(prevArgs, nextDataPath, callArgs || true)\n}\n\n/**\n * Dynamically creates a fluent API from a `modelAction` and a `dmmfModelName`.\n * We use the current `dmmfModelName` to determine what can be chained on next.\n * The fluent API allows to chain on model relations to provide an alternative\n * way to fetch and access nested data all at once. When triggered, it calls\n * `modelActions` after having accumulated `prevDataPath` and `prevUserArgs`\n * with the chaining. You can find an example of usage at {@link applyModel}.\n * @param client to provide dmmf information\n * @param dmmfModelName the dmmf name of the model to apply the api to\n * @param modelAction a callback action that triggers request execution\n * @param fluentPropName the name of the api link that was just called\n * @param prevDataPath the dataPath from the previous api link\n * @param prevUserArgs the userArgs from the previous api link\n * @remarks optional parameters are empty on the first call via\n * {@link applyModel}\n * @returns\n */\nexport function applyFluent(\n client: Client,\n dmmfModelName: string,\n modelAction: ModelAction,\n fluentPropName?: string,\n prevDataPath?: string[],\n prevUserArgs?: UserArgs,\n) {\n // we retrieve the model that is described from the DMMF\n const dmmfModel = client._runtimeDataModel.models[dmmfModelName]\n\n // map[field.name] === field, basically for quick access\n const dmmfModelFieldMap = dmmfModel.fields.reduce(\n (acc, field) => ({ ...acc, [field.name]: field }),\n {} as { [dmmfModelFieldName: string]: DMMF.Field },\n )\n\n // we return a regular model action but proxy its return\n return (userArgs?: UserArgs) => {\n const callsite = getCallSite(client._errorFormat)\n // ! first call: nextDataPath => [], nextUserArgs => userArgs\n const nextDataPath = getNextDataPath(fluentPropName, prevDataPath)\n const nextUserArgs = getNextUserArgs(userArgs, prevUserArgs, nextDataPath)\n const prismaPromise = modelAction({ dataPath: nextDataPath, callsite })(nextUserArgs)\n // TODO: use an unpacker here instead of ClientFetcher logic\n // TODO: once it's done we can deprecate the use of dataPath\n const ownKeys = getOwnKeys(client, dmmfModelName)\n\n // we take control of the return promise to allow chaining\n return new Proxy(prismaPromise, {\n get(target, prop: string) {\n // fluent api only works on fields that are relational\n if (!ownKeys.includes(prop)) return target[prop]\n\n // here we are sure that prop is a field of type object\n const dmmfModelName = dmmfModelFieldMap[prop].type\n const modelArgs = [dmmfModelName, modelAction, prop] as const\n const dataArgs = [nextDataPath, nextUserArgs] as const\n\n // we allow for chaining more with this recursive call\n return applyFluent(client, ...modelArgs, ...dataArgs)\n },\n ...defaultProxyHandlers([...ownKeys, ...Object.getOwnPropertyNames(prismaPromise)]),\n })\n }\n}\n\n// the only accessible fields are relations to be chained on\nfunction getOwnKeys(client: Client, dmmfModelName: string) {\n return client._runtimeDataModel.models[dmmfModelName].fields\n .filter((field) => field.kind === 'object') // relations\n .map((field) => field.name)\n}\n", "import * as DMMF from '@prisma/dmmf'\nimport type { O } from 'ts-toolbelt'\n\nimport { type Client, type InternalRequestParams } from '../../getPrismaClient'\nimport { getCallSite } from '../../utils/CallSite'\nimport {\n addObjectProperties,\n addProperty,\n cacheProperties,\n CompositeProxyLayer,\n createCompositeProxy,\n} from '../compositeProxy'\nimport type { PrismaPromise } from '../request/PrismaPromise'\nimport type { UserArgs } from '../request/UserArgs'\nimport { applyAggregates } from './applyAggregates'\nimport { applyFieldsProxy } from './applyFieldsProxy'\nimport { applyFluent } from './applyFluent'\nimport { dmmfToJSModelName } from './utils/dmmfToJSModelName'\n\nexport type ModelAction = (\n paramOverrides: O.Optional<InternalRequestParams>,\n) => (userArgs?: UserArgs) => PrismaPromise<unknown>\n\nconst fluentProps = [\n 'findUnique',\n 'findUniqueOrThrow',\n 'findFirst',\n 'findFirstOrThrow',\n 'create',\n 'update',\n 'upsert',\n 'delete',\n] as const\nconst aggregateProps = ['aggregate', 'count', 'groupBy'] as const\n\n/**\n * Dynamically creates a model interface via a proxy.\n * @param client to trigger the request execution\n * @param dmmfModelName the dmmf name of the model\n * @returns\n */\nexport function applyModel(client: Client, dmmfModelName: string) {\n const modelExtensions = client._extensions.getAllModelExtensions(dmmfModelName) ?? {}\n\n const layers = [\n modelActionsLayer(client, dmmfModelName),\n fieldsPropertyLayer(client, dmmfModelName),\n addObjectProperties(modelExtensions),\n addProperty('name', () => dmmfModelName),\n addProperty('$name', () => dmmfModelName),\n addProperty('$parent', () => client._appliedParent),\n ]\n\n return createCompositeProxy({}, layers)\n}\n\n/**\n * Dynamically creates a model interface via a proxy.\n * @param client to trigger the request execution\n * @param dmmfModelName the dmmf name of the model\n * @returns\n */\nfunction modelActionsLayer(client: Client, dmmfModelName: string): CompositeProxyLayer<string> {\n // we use the javascript model name for display purposes\n const jsModelName = dmmfToJSModelName(dmmfModelName)\n const ownKeys = Object.keys(DMMF.ModelAction).concat('count')\n\n return {\n getKeys() {\n return ownKeys\n },\n\n getPropertyValue(key) {\n const dmmfActionName = key as DMMF.ModelAction\n\n // we return a function as the model action that we want to expose\n // it takes user args and executes the request in a Prisma Promise\n const action = (paramOverrides: O.Optional<InternalRequestParams>) => (userArgs?: UserArgs) => {\n const callSite = getCallSite(client._errorFormat) // used for showing better errors\n\n return client._createPrismaPromise(\n (transaction) => {\n const params: InternalRequestParams = {\n // data and its dataPath for nested results\n args: userArgs,\n dataPath: [],\n\n // action name and its related model\n action: dmmfActionName,\n model: dmmfModelName,\n\n // method name for display only\n clientMethod: `${jsModelName}.${key}`,\n jsModelName,\n\n // transaction information\n transaction,\n\n // stack trace\n callsite: callSite,\n }\n\n return client._request({ ...params, ...paramOverrides })\n },\n {\n action: dmmfActionName,\n args: userArgs,\n model: dmmfModelName,\n },\n )\n }\n\n // we give the control over action for building the fluent api\n if ((fluentProps as readonly string[]).includes(dmmfActionName)) {\n return applyFluent(client, dmmfModelName, action)\n }\n\n // we handle the edge case of aggregates that need extra steps\n if (isValidAggregateName(key)) {\n return applyAggregates(client, key, action)\n }\n\n return action({}) // and by default, don't override any params\n },\n }\n}\n\nfunction isValidAggregateName(action: string): action is (typeof aggregateProps)[number] {\n return (aggregateProps as readonly string[]).includes(action)\n}\n\nfunction fieldsPropertyLayer(client: Client, dmmfModelName: string) {\n return cacheProperties(\n addProperty('fields', () => {\n const model = client._runtimeDataModel.models[dmmfModelName]\n return applyFieldsProxy(dmmfModelName, model)\n }),\n )\n}\n", "/**\n * Transforms a model name coming from the runtime to a DMMF model name.\n * @param name\n * @returns\n */\nexport function jsToDMMFModelName(name: string) {\n return name.replace(/^./, (str) => str.toUpperCase())\n}\n", "import type { Client } from '../../getPrismaClient'\nimport {\n addObjectProperties,\n addProperty,\n cacheProperties,\n CompositeProxyLayer,\n createCompositeProxy,\n} from '../compositeProxy'\nimport { applyModel } from './applyModel'\nimport { dmmfToJSModelName } from './utils/dmmfToJSModelName'\nimport { jsToDMMFModelName } from './utils/jsToDMMFModelName'\n\n// symbol we use for storing raw, unproxied\n// client instance, so we later can retrieve it\n// via `unapplyModels` methods\nconst rawClient = Symbol()\n\n/**\n * Dynamically creates a model proxy interface for a give name. For each prop\n * accessed on this proxy, it will lookup the dmmf to find if that model exists.\n * If it is the case, it will create a proxy for that model via {@link applyModel}.\n * @param client to create the proxy around\n * @returns a proxy to access models\n */\nexport function applyModelsAndClientExtensions(client: Client) {\n const layers = [\n rootLayer(client),\n modelsLayer(client),\n addProperty(rawClient, () => client),\n addProperty('$parent', () => client._appliedParent),\n ]\n const clientExtensions = client._extensions.getAllClientExtensions()\n if (clientExtensions) {\n layers.push(addObjectProperties(clientExtensions))\n }\n return createCompositeProxy(client, layers)\n}\n\nfunction rootLayer(client: Client): CompositeProxyLayer {\n const prototype = Object.getPrototypeOf(client._originalClient)\n const allKeys = [...new Set(Object.getOwnPropertyNames(prototype))]\n\n return {\n getKeys() {\n return allKeys\n },\n\n getPropertyValue(prop) {\n return client[prop]\n },\n }\n}\n\nfunction modelsLayer(client: Client): CompositeProxyLayer {\n const dmmfModelKeys = Object.keys(client._runtimeDataModel.models)\n const jsModelKeys = dmmfModelKeys.map(dmmfToJSModelName)\n const allKeys = [...new Set(dmmfModelKeys.concat(jsModelKeys))]\n\n return cacheProperties({\n getKeys() {\n return allKeys\n },\n\n getPropertyValue(prop) {\n const dmmfModelName = jsToDMMFModelName(prop)\n // creates a new model proxy on the fly and caches it\n if (client._runtimeDataModel.models[dmmfModelName] !== undefined) {\n return applyModel(client, dmmfModelName)\n }\n\n // above silently failed if model name is lower cased\n if (client._runtimeDataModel.models[prop] !== undefined) {\n return applyModel(client, prop)\n }\n\n return undefined\n },\n\n getPropertyDescriptor(key) {\n if (!jsModelKeys.includes(key)) {\n return { enumerable: false }\n }\n\n return undefined\n },\n })\n}\n\nexport function unApplyModelsAndClientExtensions(client: Client): Client {\n if (client[rawClient]) {\n return client[rawClient]\n }\n return client\n}\n", "import { Client } from '../../getPrismaClient'\nimport { applyModelsAndClientExtensions } from '../model/applyModelsAndClientExtensions'\nimport { ExtensionArgs } from '../types/exported'\n\n/**\n * @param this\n */\nexport function $extends(this: Client, extension: ExtensionArgs | ((client: Client) => Client)): Client {\n if (typeof extension === 'function') {\n return extension(this)\n }\n\n const newClient = Object.create(this._originalClient, {\n _extensions: { value: this._extensions.append(extension) },\n _appliedParent: { value: this, configurable: true },\n $on: { value: undefined },\n }) as Client\n\n return applyModelsAndClientExtensions(newClient)\n}\n", "import { hasOwnProperty } from '@prisma/internals'\n\nimport {\n addProperty,\n cacheProperties,\n CompositeProxyLayer,\n createCompositeProxy,\n removeProperties,\n} from '../compositeProxy'\nimport { Omission, Selection } from '../types/exported/JsApi'\nimport { MergedExtensionsList } from './MergedExtensionsList'\nimport { ComputedField } from './resultUtils'\n\ntype ApplyExtensionsArgs = {\n result: object\n select?: Selection\n omit?: Omission\n modelName: string\n extensions: MergedExtensionsList\n}\n\n/**\n * Given a part of a query result, it's model name and a list of extension,\n * applies computed fields to the results. Fields are computed lazily on a first access,\n * after that the result of computation is cached. In case `select` is used, all dependencies\n * of the computed fields would be excluded from final result, unless they are also specified in the select.\n *\n * This function applies computed fields to a single object only: it does not traverse relationships.\n * For full functionality, it is meant to be combined with `visitQueryResult`.\n *\n * @param params\n * @returns\n */\nexport function applyResultExtensions({ result, modelName, select, omit, extensions }: ApplyExtensionsArgs) {\n const computedFields = extensions.getAllComputedFields(modelName)\n if (!computedFields) {\n return result\n }\n\n const computedPropertiesLayers: CompositeProxyLayer[] = []\n const maskingLayers: CompositeProxyLayer[] = []\n\n for (const field of Object.values(computedFields)) {\n if (omit) {\n if (omit[field.name]) {\n continue\n }\n const toMask = field.needs.filter((prop) => omit[prop])\n if (toMask.length > 0) {\n maskingLayers.push(removeProperties(toMask))\n }\n } else if (select) {\n if (!select[field.name]) {\n continue\n }\n\n const toMask = field.needs.filter((prop) => !select[prop])\n if (toMask.length > 0) {\n maskingLayers.push(removeProperties(toMask))\n }\n }\n\n if (areNeedsMet(result, field.needs)) {\n computedPropertiesLayers.push(\n computedPropertyLayer(field, createCompositeProxy(result, computedPropertiesLayers)),\n )\n }\n }\n\n if (computedPropertiesLayers.length > 0 || maskingLayers.length > 0) {\n return createCompositeProxy(result, [...computedPropertiesLayers, ...maskingLayers])\n }\n return result\n}\n\nfunction areNeedsMet(result: object, neededProperties: string[]) {\n return neededProperties.every((property) => hasOwnProperty(result, property))\n}\n\nfunction computedPropertyLayer(field: ComputedField, result: object): CompositeProxyLayer {\n return cacheProperties(addProperty(field.name, () => field.compute(result)))\n}\n", "import { RuntimeDataModel } from '@prisma/client-common'\n\nimport { isSkip } from '../types'\nimport { JsArgs, Selection } from '../types/exported/JsApi'\n\ntype ModelVisitor = (value: object, modelName: string, queryArgs: JsArgs) => object | undefined\n\ntype VisitParams = {\n result: object\n args: JsArgs\n modelName: string\n runtimeDataModel: RuntimeDataModel\n visitor: ModelVisitor\n}\n\n/**\n * Function recursively walks through provided query response using `include` and `select`\n * query parameters and calls `visitor` callback for each model it encounters.\n * `visitor` receives the value of a particular response section, model it corresponds to and\n * the arguments used to query it. If visitor returns any non-undefined value that value will\n * replace corresponding part of the final result.\n *\n * @param params\n * @returns\n */\nexport function visitQueryResult({ visitor, result, args, runtimeDataModel, modelName }: VisitParams) {\n if (Array.isArray(result)) {\n for (let i = 0; i < result.length; i++) {\n result[i] = visitQueryResult({\n result: result[i],\n args,\n modelName,\n runtimeDataModel,\n visitor,\n })\n }\n return result\n }\n const visitResult = visitor(result, modelName, args) ?? result\n if (args.include) {\n visitNested({\n includeOrSelect: args.include,\n result: visitResult,\n parentModelName: modelName,\n runtimeDataModel,\n visitor,\n })\n }\n if (args.select) {\n visitNested({\n includeOrSelect: args.select,\n result: visitResult,\n parentModelName: modelName,\n runtimeDataModel,\n visitor,\n })\n }\n return visitResult\n}\n\ntype VisitNestedParams = {\n includeOrSelect: Selection\n result: object\n parentModelName: string\n runtimeDataModel: RuntimeDataModel\n visitor: ModelVisitor\n}\n\nfunction visitNested({ includeOrSelect, result, parentModelName, runtimeDataModel, visitor }: VisitNestedParams) {\n for (const [fieldName, subConfig] of Object.entries(includeOrSelect)) {\n if (!subConfig || result[fieldName] == null || isSkip(subConfig)) {\n continue\n }\n const parentModel = runtimeDataModel.models[parentModelName]\n const field = parentModel.fields.find((field) => field.name === fieldName)\n if (!field || field.kind !== 'object' || !field.relationName) {\n continue\n }\n const args = typeof subConfig === 'object' ? subConfig : {}\n result[fieldName] = visitQueryResult({\n visitor,\n result: result[fieldName],\n args,\n modelName: field.type,\n runtimeDataModel,\n })\n }\n}\n", "import { RuntimeDataModel } from '@prisma/client-common'\n\nimport { GlobalOmitOptions } from '../jsonProtocol/serializeJsonQuery'\nimport { dmmfToJSModelName } from '../model/utils/dmmfToJSModelName'\nimport { JsArgs } from '../types/exported/JsApi'\nimport { applyResultExtensions } from './applyResultExtensions'\nimport { MergedExtensionsList } from './MergedExtensionsList'\nimport { visitQueryResult } from './visitQueryResult'\n\ntype ApplyAllResultExtensionsParams = {\n result: object | null\n modelName: string\n args: JsArgs\n extensions: MergedExtensionsList\n runtimeDataModel: RuntimeDataModel\n globalOmit?: GlobalOmitOptions\n}\n\n/**\n * Walks the result of the query and applies all possible result extensions\n * to all parts of it, including nested relations\n */\nexport function applyAllResultExtensions({\n result,\n modelName,\n args,\n extensions,\n runtimeDataModel,\n globalOmit,\n}: ApplyAllResultExtensionsParams) {\n // We return the result directly (not applying result extensions) if\n // - there is no extension to apply\n // - result is `null`\n // - result is not an object (e.g. `.count()`)\n if (extensions.isEmpty() || result == null || typeof result !== 'object') {\n return result\n }\n const model = runtimeDataModel.models[modelName]\n if (!model) {\n return result\n }\n\n return visitQueryResult({\n result,\n args: args ?? {},\n modelName,\n runtimeDataModel,\n visitor: (value, dmmfModelName, args) => {\n const jsName = dmmfToJSModelName(dmmfModelName)\n return applyResultExtensions({\n result: value,\n modelName: jsName,\n select: args.select,\n // passing omit only if explicit select is not set - those 2 options are\n // mutually exclusive\n omit: args.select ? undefined : { ...globalOmit?.[jsName], ...args.omit },\n extensions,\n })\n },\n })\n}\n", "import { Decimal, ObjectEnumValue, Sql } from '@prisma/client-runtime-utils'\nimport { assertNever } from '@prisma/internals'\n\nimport { isFieldRef } from '../core/model/FieldRef'\nimport { isTypedSql, TypedSql, UnknownTypedSql } from '../core/types/exported'\nimport { JsArgs, JsInputValue } from '../core/types/exported/JsApi'\nimport { RawQueryArgs } from '../core/types/exported/RawQueryArgs'\nimport { isDate } from './date'\nimport { isDecimalJsLike } from './decimalJsLike'\n\nexport function deepCloneArgs(args: JsArgs | RawQueryArgs): JsArgs | RawQueryArgs {\n if (args instanceof Sql) {\n return cloneSql(args)\n }\n\n if (isTypedSql(args)) {\n return cloneTypedSql(args)\n }\n\n if (Array.isArray(args)) {\n const clone: RawQueryArgs = [args[0]]\n\n for (let i = 1; i < args.length; i++) {\n clone[i] = deepCloneValue(args[i] as JsInputValue)\n }\n\n return clone\n }\n const clone: JsArgs = {}\n for (const k in args) {\n clone[k] = deepCloneValue(args[k])\n }\n return clone\n}\n\nfunction cloneSql(rawParam: Sql): Sql {\n return new Sql(rawParam.strings, rawParam.values)\n}\n\nfunction cloneTypedSql(rawParam: UnknownTypedSql): UnknownTypedSql {\n return new TypedSql(rawParam.sql, rawParam.values)\n}\n\n// based on https://github.com/lukeed/klona/blob/v2.0.6/src/index.js\nfunction deepCloneValue(x: JsInputValue): JsInputValue {\n if (typeof x !== 'object' || x == null || x instanceof ObjectEnumValue || isFieldRef(x)) {\n return x\n }\n\n if (isDecimalJsLike(x)) {\n return new Decimal(x.toFixed())\n }\n\n if (isDate(x)) {\n return new Date(+x)\n }\n\n if (ArrayBuffer.isView(x)) {\n return x.slice(0)\n }\n\n if (Array.isArray(x)) {\n let k = x.length\n let copy\n for (copy = Array(k); k--; ) {\n copy[k] = deepCloneValue(x[k])\n }\n return copy\n }\n\n if (typeof x === 'object') {\n const copy = {}\n for (const k in x) {\n if (k === '__proto__') {\n Object.defineProperty(copy, k, {\n value: deepCloneValue(x[k]),\n configurable: true,\n enumerable: true,\n writable: true,\n })\n } else {\n copy[k] = deepCloneValue(x[k])\n }\n }\n return copy\n }\n\n assertNever(x, 'Unknown value')\n}\n", "const denylist = ['$connect', '$disconnect', '$on', '$transaction', '$extends'] as const\n\nexport const itxClientDenyList = denylist as ReadonlyArray<string | symbol>\n\nexport type ITXClientDenyList = (typeof denylist)[number]\n", "import { Client, InternalRequestParams } from '../../getPrismaClient'\nimport { RequestParams } from '../../RequestHandler'\nimport { deepCloneArgs } from '../../utils/deepCloneArgs'\nimport { AccelerateExtensionFetchDecorator } from '../engines'\nimport { QueryOptionsCb } from '../types/exported/ExtensionArgs'\nimport { BatchInternalParams, BatchQueryOptionsCb } from '../types/internal/ExtensionsInternalArgs'\n\nfunction iterateAndCallQueryCallbacks(\n client: Client,\n params: InternalRequestParams,\n queryCbs: QueryOptionsCb[],\n i = 0,\n) {\n return client._createPrismaPromise((transaction) => {\n // we need to keep track of the previous customDataProxyFetch\n const prevCustomFetch = params.customDataProxyFetch\n\n // allow query extensions to re-wrap in transactions\n // this will automatically discard the prev batch tx\n if ('transaction' in params && transaction !== undefined) {\n if (params.transaction?.kind === 'batch') {\n void params.transaction.lock.then() // discard\n }\n params.transaction = transaction\n }\n\n // if we are done recursing, we execute the request\n if (i === queryCbs.length) {\n return client._executeRequest(params)\n }\n\n // if not, call the next query cb and recurse query\n return queryCbs[i]({\n model: params.model,\n operation: params.model ? params.action : params.clientMethod,\n args: deepCloneArgs(params.args ?? {}),\n // @ts-expect-error because not part of public API\n __internalParams: params,\n query: (args, __internalParams = params) => {\n // we need to keep track of the current customDataProxyFetch\n // this is to cascade customDataProxyFetch like a middleware\n const currCustomFetch = __internalParams.customDataProxyFetch\n __internalParams.customDataProxyFetch = composeCustomDataProxyFetch(prevCustomFetch, currCustomFetch)\n __internalParams.args = args\n\n return iterateAndCallQueryCallbacks(client, __internalParams, queryCbs, i + 1)\n },\n })\n })\n}\n\nexport function applyQueryExtensions(client: Client, params: InternalRequestParams): Promise<any> {\n const { jsModelName, action, clientMethod } = params\n const operation = jsModelName ? action : clientMethod\n\n // query extensions only apply to model-bound operations\n if (client._extensions.isEmpty()) {\n return client._executeRequest(params)\n }\n\n // get the cached query cbs for a given model and action\n const cbs = client._extensions.getAllQueryCallbacks(jsModelName ?? '$none', operation)\n\n return iterateAndCallQueryCallbacks(client, params, cbs)\n}\n\ntype BatchExecuteCallback = (params: BatchInternalParams) => Promise<unknown[]>\n\nexport function createApplyBatchExtensionsFunction(executeBatch: BatchExecuteCallback) {\n return (requests: RequestParams[]) => {\n const params = { requests }\n const callbacks = requests[0].extensions.getAllBatchQueryCallbacks()\n if (!callbacks.length) {\n return executeBatch(params)\n }\n\n return iterateAndCallBatchCallbacks(params, callbacks, 0, executeBatch)\n }\n}\n\nexport function iterateAndCallBatchCallbacks(\n params: BatchInternalParams,\n callbacks: BatchQueryOptionsCb[],\n i: number,\n executeBatch: BatchExecuteCallback,\n) {\n if (i === callbacks.length) {\n return executeBatch(params)\n }\n\n const prevFetch = params.customDataProxyFetch\n const transaction = params.requests[0].transaction\n return callbacks[i]({\n args: {\n queries: params.requests.map((request) => ({\n model: request.modelName,\n operation: request.action,\n args: request.args,\n })),\n transaction: transaction\n ? {\n isolationLevel: transaction.kind === 'batch' ? transaction.isolationLevel : undefined,\n }\n : undefined,\n },\n __internalParams: params,\n query(_args, __internalParams = params) {\n const nextFetch = __internalParams.customDataProxyFetch\n __internalParams.customDataProxyFetch = composeCustomDataProxyFetch(prevFetch, nextFetch)\n return iterateAndCallBatchCallbacks(__internalParams, callbacks, i + 1, executeBatch)\n },\n })\n}\n\nconst noopFetch: AccelerateExtensionFetchDecorator = (f) => f\nfunction composeCustomDataProxyFetch(prevFetch = noopFetch, nextFetch = noopFetch): AccelerateExtensionFetchDecorator {\n return (f) => prevFetch(nextFetch(f))\n}\n", "import { Decimal } from '@prisma/client-runtime-utils'\n\nimport { assertNever } from './utils'\n\nexport type DateTaggedValue = { $type: 'DateTime'; value: string }\nexport type DecimalTaggedValue = { $type: 'Decimal'; value: string }\nexport type BytesTaggedValue = { $type: 'Bytes'; value: string }\nexport type BigIntTaggedValue = { $type: 'BigInt'; value: string }\nexport type FieldRefTaggedValue = { $type: 'FieldRef'; value: { _ref: string } }\nexport type EnumTaggedValue = { $type: 'Enum'; value: string }\nexport type JsonTaggedValue = { $type: 'Json'; value: string }\n\nexport type JsonInputTaggedValue =\n | DateTaggedValue\n | DecimalTaggedValue\n | BytesTaggedValue\n | BigIntTaggedValue\n | FieldRefTaggedValue\n | JsonTaggedValue\n | EnumTaggedValue\n\nexport type JsonOutputTaggedValue =\n | DateTaggedValue\n | DecimalTaggedValue\n | BytesTaggedValue\n | BigIntTaggedValue\n | JsonTaggedValue\n\nexport type JsOutputValue =\n | null\n | string\n | number\n | boolean\n | bigint\n | Uint8Array\n | Date\n | Decimal\n | JsOutputValue[]\n | { [key: string]: JsOutputValue }\n\nexport function normalizeJsonProtocolValues(result: unknown): unknown {\n if (result === null) {\n return result\n }\n\n if (Array.isArray(result)) {\n return result.map(normalizeJsonProtocolValues)\n }\n\n if (typeof result === 'object') {\n if (isTaggedValue(result)) {\n return normalizeTaggedValue(result)\n }\n\n if (ArrayBuffer.isView(result)) {\n const buffer = Buffer.from(result.buffer, result.byteOffset, result.byteLength)\n return buffer.toString('base64')\n }\n\n // avoid mapping class instances\n if (result.constructor !== null && result.constructor.name !== 'Object') {\n return result\n }\n\n return mapObjectValues(result, normalizeJsonProtocolValues)\n }\n\n return result\n}\n\nfunction isTaggedValue(value: unknown): value is JsonOutputTaggedValue {\n return value !== null && typeof value == 'object' && typeof value['$type'] === 'string'\n}\n\n/**\n * Normalizes the value inside a tagged value to match the snapshots in tests.\n * Sometimes there are multiple equally valid representations of the same value\n * (e.g. a decimal string may contain an arbitrary number of trailing zeros,\n * datetime strings may specify the UTC offset as either '+00:00' or 'Z', etc).\n * Since these differences have no effect on the actual values received from the\n * Prisma Client once the response is deserialized to JavaScript values, we don't\n * spend extra CPU cycles on normalizing them in the data mapper. Instead, we\n * patch and normalize them here to ensure they are consistent with the snapshots\n * in the query engine tests.\n */\nfunction normalizeTaggedValue({ $type, value }: JsonOutputTaggedValue): JsonOutputTaggedValue {\n switch ($type) {\n case 'BigInt':\n return { $type, value: String(value) }\n case 'Bytes':\n return { $type, value: Buffer.from(value, 'base64').toString('base64') }\n case 'DateTime':\n return { $type, value: new Date(value).toISOString() }\n case 'Decimal':\n return { $type, value: String(new Decimal(value)) }\n case 'Json':\n return { $type, value: JSON.stringify(JSON.parse(value)) }\n default:\n assertNever(value, 'Unknown tagged value')\n }\n}\n\nfunction mapObjectValues<K extends PropertyKey, T, U>(\n object: Record<K, T>,\n mapper: (value: T, key: K) => U,\n): Record<K, U> {\n const result = {} as Record<K, U>\n\n for (const key of Object.keys(object)) {\n result[key] = mapper(object[key] as T, key as K)\n }\n\n return result\n}\n\nexport function deserializeJsonResponse(result: unknown): unknown {\n if (result === null) {\n return result\n }\n\n if (Array.isArray(result)) {\n return result.map(deserializeJsonResponse)\n }\n\n if (typeof result === 'object') {\n if (isTaggedValue(result)) {\n return deserializeTaggedValue(result)\n }\n\n // avoid mapping class instances\n if (result.constructor !== null && result.constructor.name !== 'Object') {\n return result\n }\n\n return mapObjectValues(result, deserializeJsonResponse)\n }\n\n return result\n}\n\nfunction deserializeTaggedValue({ $type, value }: JsonOutputTaggedValue): JsOutputValue {\n switch ($type) {\n case 'BigInt':\n return BigInt(value)\n case 'Bytes': {\n const { buffer, byteOffset, byteLength } = Buffer.from(value, 'base64')\n return new Uint8Array(buffer, byteOffset, byteLength)\n }\n case 'DateTime':\n return new Date(value)\n case 'Decimal':\n return new Decimal(value)\n case 'Json':\n return JSON.parse(value)\n default:\n assertNever(value, 'Unknown tagged value')\n }\n}\n", "import { Decimal } from '@prisma/client-runtime-utils'\n\n// Copied over to avoid the heavy dependency on `@prisma/internals` with its\n// transitive dependencies that are not needed for other query plan executor\n// implementations outside of Prisma Client (e.g. test executor for query\n// engine tests and query plan executor for Accelerate) that also depend on\n// `@prisma/client-engine-runtime`.\nexport function assertNever(_: never, message: string): never {\n throw new Error(message)\n}\n\n/**\n * Checks if two objects are deeply equal, recursively checking all properties for strict equality.\n */\nexport function isDeepStrictEqual(a: unknown, b: unknown): boolean {\n return (\n a === b ||\n (a !== null &&\n b !== null &&\n typeof a === 'object' &&\n typeof b === 'object' &&\n Object.keys(a).length === Object.keys(b).length &&\n Object.keys(a).every((key) => isDeepStrictEqual(a[key], b[key])))\n )\n}\n\n/**\n * Checks if two objects representing the names and values of key columns match. A match is\n * defined by one of the sets of keys being a subset of the other. This function also\n * converts arguments to the types used by driver adapters if necessary.\n */\nexport function doKeysMatch(lhs: {}, rhs: {}): boolean {\n const lhsKeys = Object.keys(lhs)\n const rhsKeys = Object.keys(rhs)\n const smallerKeyList = lhsKeys.length < rhsKeys.length ? lhsKeys : rhsKeys\n\n return smallerKeyList.every((key) => {\n if (typeof lhs[key] === typeof rhs[key] && typeof lhs[key] !== 'object') {\n // fast path for primitive types\n return lhs[key] === rhs[key]\n }\n\n if (Decimal.isDecimal(lhs[key]) || Decimal.isDecimal(rhs[key])) {\n const lhsDecimal = asDecimal(lhs[key])\n const rhsDecimal = asDecimal(rhs[key])\n return lhsDecimal && rhsDecimal && lhsDecimal.equals(rhsDecimal)\n } else if (lhs[key] instanceof Uint8Array || rhs[key] instanceof Uint8Array) {\n const lhsBuffer = asBuffer(lhs[key])\n const rhsBuffer = asBuffer(rhs[key])\n return lhsBuffer && rhsBuffer && lhsBuffer.equals(rhsBuffer)\n } else if (lhs[key] instanceof Date || rhs[key] instanceof Date) {\n return asDate(lhs[key])?.getTime() === asDate(rhs[key])?.getTime()\n } else if (typeof lhs[key] === 'bigint' || typeof rhs[key] === 'bigint') {\n return asBigInt(lhs[key]) === asBigInt(rhs[key])\n } else if (typeof lhs[key] === 'number' || typeof rhs[key] === 'number') {\n return asNumber(lhs[key]) === asNumber(rhs[key])\n }\n\n return isDeepStrictEqual(lhs[key], rhs[key])\n })\n}\n\nfunction asDecimal(value: unknown): Decimal | undefined {\n if (Decimal.isDecimal(value)) {\n return value\n } else if (typeof value === 'number' || typeof value === 'string') {\n return new Decimal(value)\n } else {\n return\n }\n}\n\nfunction asBuffer(value: unknown): Buffer | undefined {\n if (Buffer.isBuffer(value)) {\n return value\n } else if (value instanceof Uint8Array) {\n return Buffer.from(value.buffer, value.byteOffset, value.byteLength)\n } else if (typeof value === 'string') {\n return Buffer.from(value, 'base64')\n } else {\n return\n }\n}\n\nfunction asDate(value: unknown): Date | undefined {\n if (value instanceof Date) {\n return value\n } else if (typeof value === 'string' || typeof value === 'number') {\n return new Date(value)\n } else {\n return\n }\n}\n\nfunction asBigInt(value: unknown): bigint | undefined {\n if (typeof value === 'bigint') {\n return value\n } else if (typeof value === 'number' || typeof value === 'string') {\n return BigInt(value)\n } else {\n return\n }\n}\n\nfunction asNumber(value: unknown): number | undefined {\n if (typeof value === 'number') {\n return value\n } else if (typeof value === 'string') {\n return Number(value)\n } else {\n return\n }\n}\n\n/**\n * `JSON.stringify` wrapper with custom replacer function that handles nested\n * BigInt and Uint8Array values.\n */\nexport function safeJsonStringify(obj: unknown): string {\n return JSON.stringify(obj, (_key, val) => {\n if (typeof val === 'bigint') {\n return val.toString()\n } else if (ArrayBuffer.isView(val)) {\n return Buffer.from(val.buffer, val.byteOffset, val.byteLength).toString('base64')\n }\n return val\n })\n}\n", "import { Error as ErrorObject } from './types'\n\nexport class DriverAdapterError extends Error {\n name = 'DriverAdapterError'\n cause: ErrorObject\n\n constructor(payload: ErrorObject) {\n super(typeof payload['message'] === 'string' ? payload['message'] : payload.kind)\n this.cause = payload\n }\n}\n\nexport function isDriverAdapterError(error: any): error is DriverAdapterError {\n return error['name'] === 'DriverAdapterError' && typeof error['cause'] === 'object'\n}\n", "// Same order as in rust driver-adapters' `ColumnType`.\n// Note: exporting const enums causes lots of problems with bundlers, so we emulate\n// them via regular dictionaries.\n// See: https://hackmd.io/@dzearing/Sk3xV0cLs\nexport const ColumnTypeEnum = {\n // Scalars\n Int32: 0,\n Int64: 1,\n Float: 2,\n Double: 3,\n Numeric: 4,\n Boolean: 5,\n Character: 6,\n Text: 7,\n Date: 8,\n Time: 9,\n DateTime: 10,\n Json: 11,\n Enum: 12,\n Bytes: 13,\n Set: 14,\n Uuid: 15,\n\n // Arrays\n Int32Array: 64,\n Int64Array: 65,\n FloatArray: 66,\n DoubleArray: 67,\n NumericArray: 68,\n BooleanArray: 69,\n CharacterArray: 70,\n TextArray: 71,\n DateArray: 72,\n TimeArray: 73,\n DateTimeArray: 74,\n JsonArray: 75,\n EnumArray: 76,\n BytesArray: 77,\n UuidArray: 78,\n\n // Custom\n UnknownNumber: 128,\n} as const\n", "import { DriverAdapterError, isDriverAdapterError } from '@prisma/driver-adapter-utils'\n\nimport { assertNever } from './utils'\n\nexport class UserFacingError extends Error {\n name = 'UserFacingError'\n code: string\n meta: Record<string, unknown>\n\n constructor(message: string, code: string, meta?: Record<string, unknown>) {\n super(message)\n this.code = code\n this.meta = meta ?? {}\n }\n\n toQueryResponseErrorObject() {\n return {\n error: this.message,\n user_facing_error: {\n is_panic: false,\n message: this.message,\n meta: this.meta,\n error_code: this.code,\n },\n }\n }\n}\n\nexport function rethrowAsUserFacing(error: any): never {\n if (!isDriverAdapterError(error)) {\n throw error\n }\n\n const code = getErrorCode(error)\n const message = renderErrorMessage(error)\n if (!code || !message) {\n throw error\n }\n throw new UserFacingError(message, code, { driverAdapterError: error })\n}\n\nexport function rethrowAsUserFacingRawError(error: any): never {\n if (!isDriverAdapterError(error)) {\n throw error\n }\n\n throw new UserFacingError(\n `Raw query failed. Code: \\`${error.cause.originalCode ?? 'N/A'}\\`. Message: \\`${\n error.cause.originalMessage ?? renderErrorMessage(error)\n }\\``,\n 'P2010',\n { driverAdapterError: error },\n )\n}\n\nfunction getErrorCode(err: DriverAdapterError): string | undefined {\n switch (err.cause.kind) {\n case 'AuthenticationFailed':\n return 'P1000'\n case 'DatabaseNotReachable':\n return 'P1001'\n case 'DatabaseDoesNotExist':\n return 'P1003'\n case 'SocketTimeout':\n return 'P1008'\n case 'DatabaseAlreadyExists':\n return 'P1009'\n case 'DatabaseAccessDenied':\n return 'P1010'\n case 'TlsConnectionError':\n return 'P1011'\n case 'ConnectionClosed':\n return 'P1017'\n case 'TransactionAlreadyClosed':\n return 'P1018'\n case 'LengthMismatch':\n return 'P2000'\n case 'UniqueConstraintViolation':\n return 'P2002'\n case 'ForeignKeyConstraintViolation':\n return 'P2003'\n case 'InvalidInputValue':\n return 'P2007'\n case 'UnsupportedNativeDataType':\n return 'P2010'\n case 'NullConstraintViolation':\n return 'P2011'\n case 'ValueOutOfRange':\n return 'P2020'\n case 'TableDoesNotExist':\n return 'P2021'\n case 'ColumnNotFound':\n return 'P2022'\n case 'InvalidIsolationLevel':\n case 'InconsistentColumnData':\n return 'P2023'\n case 'MissingFullTextSearchIndex':\n return 'P2030'\n case 'TransactionWriteConflict':\n return 'P2034'\n case 'GenericJs':\n return 'P2036'\n case 'TooManyConnections':\n return 'P2037'\n case 'postgres':\n case 'sqlite':\n case 'mysql':\n case 'mssql':\n return\n default:\n assertNever(err.cause, `Unknown error: ${err.cause}`)\n }\n}\n\nfunction renderErrorMessage(err: DriverAdapterError): string | undefined {\n switch (err.cause.kind) {\n case 'AuthenticationFailed': {\n const user = err.cause.user ?? '(not available)'\n return `Authentication failed against the database server, the provided database credentials for \\`${user}\\` are not valid`\n }\n case 'DatabaseNotReachable': {\n const address = err.cause.host && err.cause.port ? `${err.cause.host}:${err.cause.port}` : err.cause.host\n return `Can't reach database server${address ? ` at ${address}` : ''}`\n }\n case 'DatabaseDoesNotExist': {\n const db = err.cause.db ?? '(not available)'\n return `Database \\`${db}\\` does not exist on the database server`\n }\n case 'SocketTimeout':\n return `Operation has timed out`\n case 'DatabaseAlreadyExists': {\n const db = err.cause.db ?? '(not available)'\n return `Database \\`${db}\\` already exists on the database server`\n }\n case 'DatabaseAccessDenied': {\n const db = err.cause.db ?? '(not available)'\n return `User was denied access on the database \\`${db}\\``\n }\n case 'TlsConnectionError': {\n return `Error opening a TLS connection: ${err.cause.reason}`\n }\n case 'ConnectionClosed': {\n return 'Server has closed the connection.'\n }\n case 'TransactionAlreadyClosed':\n return err.cause.cause\n case 'LengthMismatch': {\n const column = err.cause.column ?? '(not available)'\n return `The provided value for the column is too long for the column's type. Column: ${column}`\n }\n case 'UniqueConstraintViolation':\n return `Unique constraint failed on the ${renderConstraint(err.cause.constraint)}`\n case 'ForeignKeyConstraintViolation':\n return `Foreign key constraint violated on the ${renderConstraint(err.cause.constraint)}`\n case 'UnsupportedNativeDataType':\n return `Failed to deserialize column of type '${err.cause.type}'. If you're using $queryRaw and this column is explicitly marked as \\`Unsupported\\` in your Prisma schema, try casting this column to any supported Prisma type such as \\`String\\`.`\n case 'NullConstraintViolation':\n return `Null constraint violation on the ${renderConstraint(err.cause.constraint)}`\n case 'ValueOutOfRange':\n return `Value out of range for the type: ${err.cause.cause}`\n case 'TableDoesNotExist': {\n const table = err.cause.table ?? '(not available)'\n return `The table \\`${table}\\` does not exist in the current database.`\n }\n case 'ColumnNotFound': {\n const column = err.cause.column ?? '(not available)'\n return `The column \\`${column}\\` does not exist in the current database.`\n }\n case 'InvalidIsolationLevel':\n return `Error in connector: Conversion error: ${err.cause.level}`\n case 'InconsistentColumnData':\n return `Inconsistent column data: ${err.cause.cause}`\n case 'MissingFullTextSearchIndex':\n return 'Cannot find a fulltext index to use for the native search, try adding a @@fulltext([Fields...]) to your schema'\n case 'TransactionWriteConflict':\n return `Transaction failed due to a write conflict or a deadlock. Please retry your transaction`\n case 'GenericJs':\n return `Error in external connector (id ${err.cause.id})`\n case 'TooManyConnections':\n return `Too many database connections opened: ${err.cause.cause}`\n case 'InvalidInputValue':\n return `Invalid input value: ${err.cause.message}`\n case 'sqlite':\n case 'postgres':\n case 'mysql':\n case 'mssql':\n return\n default:\n assertNever(err.cause, `Unknown error: ${err.cause}`)\n }\n}\n\nfunction renderConstraint(constraint?: { fields: string[] } | { index: string } | { foreignKey: {} }): string {\n if (constraint && 'fields' in constraint) {\n return `fields: (${constraint.fields.map((field) => `\\`${field}\\``).join(', ')})`\n } else if (constraint && 'index' in constraint) {\n return `constraint: \\`${constraint.index}\\``\n } else if (constraint && 'foreignKey' in constraint) {\n return `foreign key`\n }\n return '(not available)'\n}\n", "import { deserializeJsonResponse } from './json-protocol'\nimport { QueryPlanNode } from './query-plan'\nimport { UserFacingError } from './user-facing-error'\nimport { doKeysMatch } from './utils'\n\nexport type BatchResponse = MultiBatchResponse | CompactedBatchResponse\n\nexport type MultiBatchResponse = {\n type: 'multi'\n plans: QueryPlanNode[]\n}\n\nexport type CompactedBatchResponse = {\n type: 'compacted'\n plan: QueryPlanNode\n arguments: Record<string, {}>[]\n nestedSelection: string[]\n keys: string[]\n expectNonEmpty: boolean\n}\n\n/**\n * Checks if a value is a placeholder.\n * Handles both formats: `{ $type: 'Param', value: { name: '...' } }` and `{ prisma__type: 'param', prisma__value: { name: '...' } }`\n */\nfunction isPlaceholder(\n value: unknown,\n): value is { $type: 'Param'; value: { name: string } } | { prisma__type: 'param'; prisma__value: { name: string } } {\n if (typeof value !== 'object' || value === null) {\n return false\n }\n const obj = value as Record<string, unknown>\n // Check for JSON protocol format: { $type: 'Param', value: { name: '...' } }\n if ('$type' in obj && obj.$type === 'Param') {\n return true\n }\n // Check for serialized ArgumentValue format: { prisma__type: 'param', prisma__value: { name: '...' } }\n if ('prisma__type' in obj && obj.prisma__type === 'param') {\n return true\n }\n return false\n}\n\n/**\n * Extracts the placeholder name from a placeholder value.\n */\nfunction getPlaceholderName(\n value: { $type: 'Param'; value: { name: string } } | { prisma__type: 'param'; prisma__value: { name: string } },\n): string | undefined {\n if ('prisma__type' in value) {\n return value.prisma__value?.name\n }\n return (value as { value: { name: string } }).value.name\n}\n\n/**\n * Resolves placeholders in an argument object using the provided placeholder values.\n */\nfunction resolveArgPlaceholders(\n args: Record<string, {}>,\n placeholderValues: Record<string, unknown>,\n): Record<string, {}> {\n const resolved: Record<string, {}> = {}\n for (const [key, value] of Object.entries(args)) {\n resolved[key] = value\n if (isPlaceholder(value)) {\n const placeholderName = getPlaceholderName(value)\n if (placeholderName && placeholderName in placeholderValues) {\n resolved[key] = placeholderValues[placeholderName] as {}\n }\n }\n }\n return resolved\n}\n\n/**\n * Converts the result of a compacted query back to result objects analogous to what queries\n * would return when executed individually.\n */\nexport function convertCompactedRows(\n rows: {}[],\n compiledBatch: CompactedBatchResponse,\n placeholderValues: Record<string, unknown> = {},\n): unknown[] {\n // a list of objects that contain the keys of every row\n const keysPerRow = rows.map((item) =>\n compiledBatch.keys.reduce((acc, key) => {\n acc[key] = deserializeJsonResponse(item[key])\n return acc\n }, {}),\n )\n\n // the selections inferred from the request, used to filter unwanted columns from the results\n const selection = new Set(compiledBatch.nestedSelection)\n\n return compiledBatch.arguments.map((args) => {\n // Resolve any placeholders in the args using the provided placeholder values\n const resolvedArgs = resolveArgPlaceholders(args, placeholderValues)\n\n // we find the index of the row that matches the input arguments - this is the row we want\n // to return minus any extra columns not present in the selection\n const rowIndex = keysPerRow.findIndex((rowKeys) => doKeysMatch(rowKeys, resolvedArgs))\n if (rowIndex === -1) {\n if (compiledBatch.expectNonEmpty) {\n return new UserFacingError(\n 'An operation failed because it depends on one or more records that were required but not found',\n 'P2025',\n )\n } else {\n return null\n }\n } else {\n const selected = Object.entries(rows[rowIndex]).filter(([k]) => selection.has(k))\n return Object.fromEntries(selected)\n }\n })\n}\n", "import { Decimal } from '@prisma/client-runtime-utils'\n\nimport { FieldScalarType, FieldType, ResultNode } from '../query-plan'\nimport { UserFacingError } from '../user-facing-error'\nimport { assertNever, safeJsonStringify } from '../utils'\nimport { PrismaObject, Value } from './scope'\n\nexport class DataMapperError extends UserFacingError {\n name = 'DataMapperError'\n\n constructor(message: string, options?: { cause?: unknown }) {\n super(message, 'P2023', options)\n }\n}\n\n// Optimization: Cache field entries to avoid repeated Object.entries() allocations per row\nconst fieldEntriesCache = new WeakMap<Record<string, ResultNode>, [string, ResultNode][]>()\n\nfunction getFieldEntries(fields: Record<string, ResultNode>): [string, ResultNode][] {\n let entries = fieldEntriesCache.get(fields)\n if (!entries) {\n entries = Object.entries(fields)\n fieldEntriesCache.set(fields, entries)\n }\n return entries\n}\n\nexport function applyDataMap(data: Value, structure: ResultNode, enums: Record<string, Record<string, string>>): Value {\n switch (structure.type) {\n case 'affectedRows':\n if (typeof data !== 'number') {\n throw new DataMapperError(`Expected an affected rows count, got: ${typeof data} (${data})`)\n }\n return { count: data }\n\n case 'object':\n return mapArrayOrObject(data, structure.fields, enums, structure.skipNulls)\n\n case 'field':\n return mapValue(data, '<result>', structure.fieldType, enums)\n\n default:\n assertNever(structure, `Invalid data mapping type: '${(structure as ResultNode).type}'`)\n }\n}\n\nfunction mapArrayOrObject(\n data: Value,\n fields: Record<string, ResultNode>,\n enums: Record<string, Record<string, string>>,\n skipNulls?: boolean,\n): PrismaObject | PrismaObject[] | null {\n if (data === null) return null\n\n if (Array.isArray(data)) {\n let rows = data as PrismaObject[]\n if (skipNulls) {\n rows = rows.filter((row) => row !== null)\n }\n return rows.map((row) => mapObject(row, fields, enums))\n }\n\n if (typeof data === 'object') {\n const row = data as PrismaObject\n return mapObject(row, fields, enums)\n }\n\n if (typeof data === 'string') {\n let decodedData: Value\n try {\n decodedData = JSON.parse(data)\n } catch (error) {\n throw new DataMapperError(`Expected an array or object, got a string that is not valid JSON`, {\n cause: error,\n })\n }\n return mapArrayOrObject(decodedData, fields, enums, skipNulls)\n }\n\n throw new DataMapperError(`Expected an array or an object, got: ${typeof data}`)\n}\n\n// Recursive\nfunction mapObject(\n data: PrismaObject,\n fields: Record<string, ResultNode>,\n enums: Record<string, Record<string, string>>,\n): PrismaObject {\n if (typeof data !== 'object') {\n throw new DataMapperError(`Expected an object, but got '${typeof data}'`)\n }\n\n const result = {}\n for (const [name, node] of getFieldEntries(fields)) {\n switch (node.type) {\n case 'affectedRows': {\n throw new DataMapperError(`Unexpected 'AffectedRows' node in data mapping for field '${name}'`)\n }\n\n case 'object': {\n const { serializedName, fields: nodeFields, skipNulls } = node\n if (serializedName !== null && !Object.hasOwn(data, serializedName)) {\n throw new DataMapperError(\n `Missing data field (Object): '${name}'; ` + `node: ${JSON.stringify(node)}; data: ${JSON.stringify(data)}`,\n )\n }\n\n const target = serializedName !== null ? data[serializedName] : data\n result[name] = mapArrayOrObject(target, nodeFields, enums, skipNulls)\n break\n }\n\n case 'field':\n {\n const dbName = node.dbName\n if (Object.hasOwn(data, dbName)) {\n result[name] = mapField(data[dbName], dbName, node.fieldType, enums)\n } else {\n throw new DataMapperError(\n `Missing data field (Value): '${dbName}'; ` +\n `node: ${JSON.stringify(node)}; data: ${JSON.stringify(data)}`,\n )\n }\n }\n break\n\n default:\n assertNever(node, `DataMapper: Invalid data mapping node type: '${(node as ResultNode).type}'`)\n }\n }\n return result\n}\n\nfunction mapField(\n value: unknown,\n columnName: string,\n fieldType: FieldType,\n enums: Record<string, Record<string, string>>,\n): unknown {\n if (value === null) {\n return fieldType.arity === 'list' ? [] : null\n }\n\n if (fieldType.arity === 'list') {\n const values = value as unknown[]\n return values.map((v, i) => mapValue(v, `${columnName}[${i}]`, fieldType, enums))\n }\n\n return mapValue(value, columnName, fieldType, enums)\n}\n\nfunction mapValue(\n value: unknown,\n columnName: string,\n scalarType: FieldScalarType,\n enums: Record<string, Record<string, string>>,\n): unknown {\n switch (scalarType.type) {\n case 'unsupported':\n return value\n\n case 'string': {\n if (typeof value !== 'string') {\n throw new DataMapperError(`Expected a string in column '${columnName}', got ${typeof value}: ${value}`)\n }\n return value\n }\n\n case 'int': {\n switch (typeof value) {\n case 'number': {\n return Math.trunc(value)\n }\n\n case 'string': {\n const numberValue = Math.trunc(Number(value))\n if (Number.isNaN(numberValue) || !Number.isFinite(numberValue)) {\n throw new DataMapperError(`Expected an integer in column '${columnName}', got string: ${value}`)\n }\n if (!Number.isSafeInteger(numberValue)) {\n throw new DataMapperError(\n `Integer value in column '${columnName}' is too large to represent as a JavaScript number without loss of precision, got: ${value}. Consider using BigInt type.`,\n )\n }\n return numberValue\n }\n\n default:\n throw new DataMapperError(`Expected an integer in column '${columnName}', got ${typeof value}: ${value}`)\n }\n }\n\n case 'bigint': {\n if (typeof value !== 'number' && typeof value !== 'string') {\n throw new DataMapperError(`Expected a bigint in column '${columnName}', got ${typeof value}: ${value}`)\n }\n return { $type: 'BigInt', value }\n }\n\n case 'float': {\n if (typeof value === 'number') return value\n if (typeof value === 'string') {\n const parsedValue = Number(value)\n if (Number.isNaN(parsedValue) && !/^[-+]?nan$/.test(value.toLowerCase())) {\n throw new DataMapperError(`Expected a float in column '${columnName}', got string: ${value}`)\n }\n return parsedValue\n }\n throw new DataMapperError(`Expected a float in column '${columnName}', got ${typeof value}: ${value}`)\n }\n\n case 'boolean': {\n if (typeof value === 'boolean') return value\n if (typeof value === 'number') return value === 1\n if (typeof value === 'string') {\n if (value === 'true' || value === 'TRUE' || value === '1') {\n return true\n } else if (value === 'false' || value === 'FALSE' || value === '0') {\n return false\n } else {\n throw new DataMapperError(`Expected a boolean in column '${columnName}', got ${typeof value}: ${value}`)\n }\n }\n if (Array.isArray(value) || value instanceof Uint8Array) {\n for (const byte of value) {\n if (byte !== 0) return true\n }\n return false\n }\n throw new DataMapperError(`Expected a boolean in column '${columnName}', got ${typeof value}: ${value}`)\n }\n\n case 'decimal':\n if (typeof value !== 'number' && typeof value !== 'string' && !Decimal.isDecimal(value)) {\n throw new DataMapperError(`Expected a decimal in column '${columnName}', got ${typeof value}: ${value}`)\n }\n return { $type: 'Decimal', value }\n\n case 'datetime': {\n if (typeof value === 'string') {\n return { $type: 'DateTime', value: normalizeDateTime(value) }\n }\n if (typeof value === 'number' || value instanceof Date) {\n return { $type: 'DateTime', value }\n }\n throw new DataMapperError(`Expected a date in column '${columnName}', got ${typeof value}: ${value}`)\n }\n\n case 'object': {\n return { $type: 'Json', value: safeJsonStringify(value) }\n }\n\n case 'json': {\n // The value received here should normally be a string, but we cannot guarantee that,\n // because of SQLite databases like D1, which can return JSON scalars directly. We therefore\n // convert the value we receive to a string.\n return { $type: 'Json', value: `${value}` }\n }\n\n case 'bytes': {\n switch (scalarType.encoding) {\n case 'base64':\n if (typeof value !== 'string') {\n throw new DataMapperError(\n `Expected a base64-encoded byte array in column '${columnName}', got ${typeof value}: ${value}`,\n )\n }\n return { $type: 'Bytes', value }\n\n case 'hex':\n if (typeof value !== 'string' || !value.startsWith('\\\\x')) {\n throw new DataMapperError(\n `Expected a hex-encoded byte array in column '${columnName}', got ${typeof value}: ${value}`,\n )\n }\n return { $type: 'Bytes', value: Buffer.from(value.slice(2), 'hex').toString('base64') }\n\n case 'array':\n if (Array.isArray(value)) {\n return { $type: 'Bytes', value: Buffer.from(value).toString('base64') }\n }\n if (value instanceof Uint8Array) {\n return { $type: 'Bytes', value: Buffer.from(value).toString('base64') }\n }\n throw new DataMapperError(`Expected a byte array in column '${columnName}', got ${typeof value}: ${value}`)\n\n default:\n assertNever(scalarType.encoding, `DataMapper: Unknown bytes encoding: ${scalarType.encoding}`)\n }\n break\n }\n\n case 'enum': {\n const enumDef = enums[scalarType.name]\n if (enumDef === undefined) {\n throw new DataMapperError(`Unknown enum '${scalarType.name}'`)\n }\n const enumValue = enumDef[`${value}`]\n if (enumValue === undefined) {\n throw new DataMapperError(`Value '${value}' not found in enum '${scalarType.name}'`)\n }\n return enumValue\n }\n\n default:\n assertNever(scalarType, `DataMapper: Unknown result type: ${scalarType['type']}`)\n }\n}\n\n/**\n * A regular expression that matches a time string with an optional timezone.\n * It matches formats like:\n * - `12:34:56`\n * - `12:34:56.789`\n * - `12:34:56Z`\n * - `12:34:56+02`\n * - `12:34:56-02:30`\n */\nconst TIME_TZ_PATTERN = /\\d{2}:\\d{2}:\\d{2}(?:\\.\\d+)?(Z|[+-]\\d{2}(:?\\d{2})?)?$/\n\n/**\n * Normalizes date time strings received from driver adapters. The returned string is always a\n * valid input for the Javascript `Date` constructor. This function will add a UTC timezone suffix\n * if there's no timezone specified, to prevent it from being interpreted as local time.\n */\nfunction normalizeDateTime(dt: string): string {\n const timeTzMatches = TIME_TZ_PATTERN.exec(dt)\n if (timeTzMatches === null) {\n // We found no time part, so we return it as a plain zulu date,\n // e.g. '2023-10-01T00:00Z'.\n // We append the time because the JS Date constructor can't parse\n // pre-1000 dates with a timezone, for example '0032-01-01Z' parses\n // as '2032-01-01T00:00:00.000Z'.\n return `${dt}T00:00:00Z`\n }\n\n let dtWithTz = dt\n const [timeTz, tz, tzMinuteOffset] = timeTzMatches\n if (tz !== undefined && tz !== 'Z' && tzMinuteOffset === undefined) {\n // If the timezone is specified as +HH or -HH (without minutes),\n // we need to suffix it with ':00' to make it a valid Date input.\n dtWithTz = `${dt}:00`\n } else if (tz === undefined) {\n // If the timezone is not specified at all, we suffix it with 'Z'.\n dtWithTz = `${dt}Z`\n }\n\n if (timeTz.length === dt.length) {\n // If the entire datetime was just the time, we prepend the unix epoch date.\n return `1970-01-01T${dtWithTz}`\n }\n\n const timeSeparatorIndex = timeTzMatches.index - 1\n // If the time part is preceded by a space, we replace it with 'T'.\n if (dtWithTz[timeSeparatorIndex] === ' ') {\n dtWithTz = `${dtWithTz.slice(0, timeSeparatorIndex)}T${dtWithTz.slice(timeSeparatorIndex + 1)}`\n }\n\n return dtWithTz\n}\n", "export function klona(x) {\n\tif (typeof x !== 'object') return x;\n\n\tvar k, tmp, str=Object.prototype.toString.call(x);\n\n\tif (str === '[object Object]') {\n\t\tif (x.constructor !== Object && typeof x.constructor === 'function') {\n\t\t\ttmp = new x.constructor();\n\t\t\tfor (k in x) {\n\t\t\t\tif (x.hasOwnProperty(k) && tmp[k] !== x[k]) {\n\t\t\t\t\ttmp[k] = klona(x[k]);\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\ttmp = {}; // null\n\t\t\tfor (k in x) {\n\t\t\t\tif (k === '__proto__') {\n\t\t\t\t\tObject.defineProperty(tmp, k, {\n\t\t\t\t\t\tvalue: klona(x[k]),\n\t\t\t\t\t\tconfigurable: true,\n\t\t\t\t\t\tenumerable: true,\n\t\t\t\t\t\twritable: true,\n\t\t\t\t\t});\n\t\t\t\t} else {\n\t\t\t\t\ttmp[k] = klona(x[k]);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn tmp;\n\t}\n\n\tif (str === '[object Array]') {\n\t\tk = x.length;\n\t\tfor (tmp=Array(k); k--;) {\n\t\t\ttmp[k] = klona(x[k]);\n\t\t}\n\t\treturn tmp;\n\t}\n\n\tif (str === '[object Set]') {\n\t\ttmp = new Set;\n\t\tx.forEach(function (val) {\n\t\t\ttmp.add(klona(val));\n\t\t});\n\t\treturn tmp;\n\t}\n\n\tif (str === '[object Map]') {\n\t\ttmp = new Map;\n\t\tx.forEach(function (val, key) {\n\t\t\ttmp.set(klona(key), klona(val));\n\t\t});\n\t\treturn tmp;\n\t}\n\n\tif (str === '[object Date]') {\n\t\treturn new Date(+x);\n\t}\n\n\tif (str === '[object RegExp]') {\n\t\ttmp = new RegExp(x.source, x.flags);\n\t\ttmp.lastIndex = x.lastIndex;\n\t\treturn tmp;\n\t}\n\n\tif (str === '[object DataView]') {\n\t\treturn new x.constructor( klona(x.buffer) );\n\t}\n\n\tif (str === '[object ArrayBuffer]') {\n\t\treturn x.slice(0);\n\t}\n\n\t// ArrayBuffer.isView(x)\n\t// ~> `new` bcuz `Buffer.slice` => ref\n\tif (str.slice(-6) === 'Array]') {\n\t\treturn new x.constructor(x);\n\t}\n\n\treturn x;\n}\n", "import type { SqlCommenterContext, SqlCommenterPlugin } from '@prisma/sqlcommenter'\nimport { klona } from 'klona'\n\n/**\n * Formats key-value pairs into a sqlcommenter-compatible comment string.\n *\n * Algorithm per https://google.github.io/sqlcommenter/spec/:\n * 1. If the map is empty, return empty string\n * 2. Sort keys lexicographically\n * 3. URL-encode keys\n * 4. URL-encode values\n * 5. Replace ' with \\' in values (after URL encoding)\n * 6. Wrap values in single quotes\n * 7. Join key='value' pairs with commas\n * 8. Wrap in a SQL comment\n */\nexport function formatSqlComment(tags: Record<string, string>): string {\n const entries = Object.entries(tags)\n if (entries.length === 0) {\n return ''\n }\n\n // Sort by key lexicographically\n entries.sort(([a], [b]) => a.localeCompare(b))\n\n const parts = entries.map(([key, value]) => {\n const encodedKey = encodeURIComponent(key)\n const encodedValue = encodeURIComponent(value).replace(/'/g, \"\\\\'\")\n return `${encodedKey}='${encodedValue}'`\n })\n\n return `/*${parts.join(',')}*/`\n}\n\n/**\n * Applies SQL commenter plugins and returns the merged key-value pairs.\n * Keys with undefined values are filtered out.\n *\n * Each plugin receives a deep clone of the context to prevent mutations\n * that could affect other plugins.\n */\nexport function applySqlCommenters(\n plugins: SqlCommenterPlugin[],\n context: SqlCommenterContext,\n): Record<string, string> {\n const merged: Record<string, string> = {}\n\n for (const plugin of plugins) {\n const tags = plugin(klona(context))\n for (const [key, value] of Object.entries(tags)) {\n if (value !== undefined) {\n merged[key] = value\n }\n }\n }\n\n return merged\n}\n\n/**\n * Applies SQL commenter plugins and returns the formatted comment.\n */\nexport function buildSqlComment(plugins: SqlCommenterPlugin[], context: SqlCommenterContext): string {\n const tags = applySqlCommenters(plugins, context)\n return formatSqlComment(tags)\n}\n\n/**\n * Appends a sqlcommenter comment to a SQL query.\n */\nexport function appendSqlComment(sql: string, comment: string): string {\n if (!comment) {\n return sql\n }\n return `${sql} ${comment}`\n}\n", "/*\n * Copyright The OpenTelemetry Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nexport enum SpanKind {\n /** Default value. Indicates that the span is used internally. */\n INTERNAL = 0,\n\n /**\n * Indicates that the span covers server-side handling of an RPC or other\n * remote request.\n */\n SERVER = 1,\n\n /**\n * Indicates that the span covers the client-side wrapper around an RPC or\n * other remote request.\n */\n CLIENT = 2,\n\n /**\n * Indicates that the span describes producer sending a message to a\n * broker. Unlike client and server, there is no direct critical path latency\n * relationship between producer and consumer spans.\n */\n PRODUCER = 3,\n\n /**\n * Indicates that the span describes consumer receiving a message from a\n * broker. Unlike client and server, there is no direct critical path latency\n * relationship between producer and consumer spans.\n */\n CONSUMER = 4,\n}\n", "import { type Context, type Span, SpanKind, type SpanOptions } from '@opentelemetry/api'\nimport type { SqlQuery } from '@prisma/driver-adapter-utils'\n\nimport { QueryEvent } from './events'\nimport type { SchemaProvider } from './schema'\nimport { assertNever } from './utils'\n\nexport type SpanCallback<R> = (span?: Span, context?: Context) => R\n\nexport type ExtendedSpanOptions = SpanOptions & {\n name: string\n}\n\n// A smaller version of the equivalent interface from `@prisma/internals`\nexport interface TracingHelper {\n isEnabled(): boolean\n runInChildSpan<R>(nameOrOptions: string | ExtendedSpanOptions, callback: SpanCallback<R>): R\n}\n\nexport const noopTracingHelper: TracingHelper = {\n isEnabled() {\n return false\n },\n runInChildSpan(_, callback) {\n return callback()\n },\n}\n\nexport function providerToOtelSystem(provider: SchemaProvider): string {\n switch (provider) {\n case 'postgresql':\n case 'postgres':\n case 'prisma+postgres':\n return 'postgresql'\n case 'sqlserver':\n return 'mssql'\n case 'mysql':\n case 'sqlite':\n case 'cockroachdb':\n case 'mongodb':\n return provider\n default:\n assertNever(provider, `Unknown provider: ${provider}`)\n }\n}\n\nexport async function withQuerySpanAndEvent<T>({\n query,\n tracingHelper,\n provider,\n onQuery,\n execute,\n}: {\n query: SqlQuery\n tracingHelper: TracingHelper\n provider: SchemaProvider\n onQuery?: (event: QueryEvent) => void\n execute: () => Promise<T>\n}): Promise<T> {\n const callback =\n onQuery === undefined\n ? execute\n : async () => {\n const timestamp = new Date()\n const startInstant = performance.now()\n const result = await execute()\n const endInstant = performance.now()\n\n onQuery({\n timestamp,\n duration: endInstant - startInstant,\n query: query.sql,\n params: query.args,\n })\n\n return result\n }\n\n if (!tracingHelper.isEnabled()) {\n return callback()\n }\n\n return await tracingHelper.runInChildSpan(\n {\n name: 'db_query',\n kind: SpanKind.CLIENT,\n attributes: {\n 'db.query.text': query.sql,\n 'db.system.name': providerToOtelSystem(provider),\n },\n },\n callback,\n )\n}\n", "export default function pad (num, size) {\n var s = '000000000' + num;\n return s.substr(s.length - size);\n}\n", "import pad from './pad.mjs';\nimport os from 'os';\n\nfunction getHostname () {\n try {\n return os.hostname();\n } catch (e) {\n /**\n * This is most likely Windows 7 which is known to cause os.hostname() to break\n * @see https://github.com/nodejs/node/issues/41297\n * @see https://github.com/libuv/libuv/issues/3260\n *\n * Fallback to take hostname from environment variables\n * @see https://docs.microsoft.com/en-us/windows-server/administration/windows-commands/hostname#notes\n */\n // eslint-disable-next-line no-underscore-dangle\n return process.env._CLUSTER_NETWORK_NAME_ || process.env.COMPUTERNAME || 'hostname';\n }\n}\n\nvar padding = 2,\n pid = pad(process.pid.toString(36), padding),\n hostname = getHostname(),\n length = hostname.length,\n hostId = pad(hostname\n .split('')\n .reduce(function (prev, char) {\n return +prev + char.charCodeAt(0);\n }, +length + 36)\n .toString(36),\n padding);\n\nexport default function fingerprint () {\n return pid + hostId;\n}\n", "/**\n * Check the provided value is a valid device id\n * @param {unknown} value\n * @returns\n */\nexport default function isCuid (value) {\n return typeof value === 'string' && (/^c[a-z0-9]{20,32}$/).test(value);\n}\n", "/**\n * cuid.js\n * Collision-resistant UID generator for browsers and node.\n * Sequential for fast db lookups and recency sorting.\n * Safe for element IDs and server-side lookups.\n *\n * Extracted from CLCTR\n *\n * Copyright (c) Eric Elliott 2012\n * MIT License\n */\n\nimport isCuid from './is-cuid.mjs';\nimport pad from './pad.mjs';\n\nexport default function createCuid (fingerprint) {\n const blockSize = 4,\n base = 36,\n discreteValues = Math.pow(base, blockSize);\n\n let c = 0;\n\n function randomBlock () {\n return pad((Math.random() *\n discreteValues << 0)\n .toString(base), blockSize);\n }\n\n function safeCounter () {\n c = c < discreteValues ? c : 0;\n c++; // this is not subliminal\n return c - 1;\n }\n\n function cuid () {\n // Starting with a lowercase letter makes\n // it HTML element ID friendly.\n var letter = 'c', // hard-coded allows for sequential access\n\n // timestamp\n // warning: this exposes the exact date and time\n // that the uid was created.\n timestamp = new Date().getTime().toString(base),\n\n // Prevent same-machine collisions.\n counter = pad(safeCounter().toString(base), blockSize),\n\n // A few chars to generate distinct ids for different\n // clients (so different computers are far less\n // likely to generate the same id)\n print = fingerprint(),\n\n // Grab some more chars from Math.random()\n random = randomBlock() + randomBlock();\n\n return letter + timestamp + counter + print + random;\n }\n\n cuid.fingerprint = fingerprint;\n cuid.isCuid = isCuid;\n\n return cuid;\n}\n\n", "/**\n * cuid.js\n * Collision-resistant UID generator for browsers and node.\n * Sequential for fast db lookups and recency sorting.\n * Safe for element IDs and server-side lookups.\n *\n * Extracted from CLCTR\n *\n * Copyright (c) Eric Elliott 2012\n * MIT License\n */\n\nimport fingerprint from '#fingerprint';\nimport createCuid from './lib/cuid.mjs';\nimport isCuid from './lib/is-cuid.mjs';\n\nconst cuid = createCuid(fingerprint);\n\nexport { fingerprint, isCuid };\n\nexport default cuid;\n", "import cuid1 from '@bugsnag/cuid'\nimport { createId as cuid2 } from '@paralleldrive/cuid2'\nimport { nanoid } from 'nanoid'\nimport { ulid } from 'ulid'\nimport { v4 as uuidv4, v7 as uuidv7 } from 'uuid'\n\nexport class GeneratorRegistry {\n #generators: GeneratorRegistrySnapshot = {}\n\n constructor() {\n this.register('uuid', new UuidGenerator())\n this.register('cuid', new CuidGenerator())\n this.register('ulid', new UlidGenerator())\n this.register('nanoid', new NanoIdGenerator())\n this.register('product', new ProductGenerator())\n }\n\n /**\n * Returns a snapshot of the generator registry. It's 'frozen' in time at the moment of this\n * method being called, meaning that the built-in time-based generators will always return\n * the same value on repeated calls as long as the same snapshot is used.\n */\n snapshot(): Readonly<GeneratorRegistrySnapshot> {\n return Object.create(this.#generators, {\n now: {\n value: new NowGenerator(),\n },\n })\n }\n\n /**\n * Registers a new generator with the given name.\n */\n register(name: string, generator: ValueGenerator): void {\n this.#generators[name] = generator\n }\n}\n\nexport interface GeneratorRegistrySnapshot {\n [key: string]: ValueGenerator\n}\n\nexport interface ValueGenerator {\n generate(...args: unknown[]): unknown\n}\n\nclass NowGenerator implements ValueGenerator {\n #now: Date = new Date()\n\n generate(): string {\n return this.#now.toISOString()\n }\n}\n\nclass UuidGenerator implements ValueGenerator {\n generate(arg: unknown): string {\n if (arg === 4) {\n return uuidv4()\n } else if (arg === 7) {\n return uuidv7()\n } else {\n throw new Error('Invalid UUID generator arguments')\n }\n }\n}\n\nclass CuidGenerator implements ValueGenerator {\n generate(arg: unknown): string {\n if (arg === 1) {\n return cuid1()\n } else if (arg === 2) {\n return cuid2()\n } else {\n throw new Error('Invalid CUID generator arguments')\n }\n }\n}\n\nclass UlidGenerator implements ValueGenerator {\n generate(): string {\n return ulid()\n }\n}\n\nclass NanoIdGenerator implements ValueGenerator {\n generate(arg: unknown): string {\n if (typeof arg === 'number') {\n return nanoid(arg)\n } else if (arg === undefined) {\n return nanoid()\n } else {\n throw new Error('Invalid Nanoid generator arguments')\n }\n }\n}\n\nclass ProductGenerator implements ValueGenerator {\n generate(lhs: unknown, rhs: unknown): unknown[] {\n if (lhs === undefined || rhs === undefined) {\n throw new Error('Invalid Product generator arguments')\n }\n\n if (Array.isArray(lhs) && Array.isArray(rhs)) {\n return lhs.flatMap((l) => rhs.map((r) => [l, r]))\n } else if (Array.isArray(lhs)) {\n return lhs.map((l) => [l, rhs])\n } else if (Array.isArray(rhs)) {\n return rhs.map((r) => [lhs, r])\n } else {\n return [[lhs, rhs]]\n }\n }\n}\n", "import { webcrypto as crypto } from 'node:crypto'\nimport { urlAlphabet as scopedUrlAlphabet } from './url-alphabet/index.js'\nexport { urlAlphabet } from './url-alphabet/index.js'\nconst POOL_SIZE_MULTIPLIER = 128\nlet pool, poolOffset\nfunction fillPool(bytes) {\n if (!pool || pool.length < bytes) {\n pool = Buffer.allocUnsafe(bytes * POOL_SIZE_MULTIPLIER)\n crypto.getRandomValues(pool)\n poolOffset = 0\n } else if (poolOffset + bytes > pool.length) {\n crypto.getRandomValues(pool)\n poolOffset = 0\n }\n poolOffset += bytes\n}\nexport function random(bytes) {\n fillPool((bytes |= 0))\n return pool.subarray(poolOffset - bytes, poolOffset)\n}\nexport function customRandom(alphabet, defaultSize, getRandom) {\n let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1\n let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length)\n return (size = defaultSize) => {\n let id = ''\n while (true) {\n let bytes = getRandom(step)\n let i = step\n while (i--) {\n id += alphabet[bytes[i] & mask] || ''\n if (id.length >= size) return id\n }\n }\n }\n}\nexport function customAlphabet(alphabet, size = 21) {\n return customRandom(alphabet, size, random)\n}\nexport function nanoid(size = 21) {\n fillPool((size |= 0))\n let id = ''\n for (let i = poolOffset - size; i < poolOffset; i++) {\n id += scopedUrlAlphabet[pool[i] & 63]\n }\n return id\n}\n", "export const urlAlphabet =\n 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict'\n", "import crypto from 'node:crypto';\n\n// These values should NEVER change. The values are precisely for\n// generating ULIDs.\nconst B32_CHARACTERS = \"0123456789ABCDEFGHJKMNPQRSTVWXYZ\";\nconst ENCODING = \"0123456789ABCDEFGHJKMNPQRSTVWXYZ\"; // Crockford's Base32\nconst ENCODING_LEN = 32; // from ENCODING.length;\nconst MAX_ULID = \"7ZZZZZZZZZZZZZZZZZZZZZZZZZ\";\nconst MIN_ULID = \"00000000000000000000000000\";\nconst RANDOM_LEN = 16;\nconst TIME_LEN = 10;\nconst TIME_MAX = 281474976710655; // from Math.pow(2, 48) - 1;\nconst ULID_REGEX = /^[0-7][0-9a-hjkmnp-tv-zA-HJKMNP-TV-Z]{25}$/;\nconst UUID_REGEX = /^[0-9a-fA-F]{8}-(?:[0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}$/;\n\nvar ULIDErrorCode;\n(function (ULIDErrorCode) {\n ULIDErrorCode[\"Base32IncorrectEncoding\"] = \"B32_ENC_INVALID\";\n ULIDErrorCode[\"DecodeTimeInvalidCharacter\"] = \"DEC_TIME_CHAR\";\n ULIDErrorCode[\"DecodeTimeValueMalformed\"] = \"DEC_TIME_MALFORMED\";\n ULIDErrorCode[\"EncodeTimeNegative\"] = \"ENC_TIME_NEG\";\n ULIDErrorCode[\"EncodeTimeSizeExceeded\"] = \"ENC_TIME_SIZE_EXCEED\";\n ULIDErrorCode[\"EncodeTimeValueMalformed\"] = \"ENC_TIME_MALFORMED\";\n ULIDErrorCode[\"PRNGDetectFailure\"] = \"PRNG_DETECT\";\n ULIDErrorCode[\"ULIDInvalid\"] = \"ULID_INVALID\";\n ULIDErrorCode[\"Unexpected\"] = \"UNEXPECTED\";\n ULIDErrorCode[\"UUIDInvalid\"] = \"UUID_INVALID\";\n})(ULIDErrorCode || (ULIDErrorCode = {}));\nclass ULIDError extends Error {\n constructor(errorCode, message) {\n super(`${message} (${errorCode})`);\n this.name = \"ULIDError\";\n this.code = errorCode;\n }\n}\n\nfunction randomChar(prng) {\n let rand = Math.floor(prng() * ENCODING_LEN);\n if (rand === ENCODING_LEN) {\n rand = ENCODING_LEN - 1;\n }\n return ENCODING.charAt(rand);\n}\nfunction replaceCharAt(str, index, char) {\n if (index > str.length - 1) {\n return str;\n }\n return str.substr(0, index) + char + str.substr(index + 1);\n}\n\n// Code from https://github.com/devbanana/crockford-base32/blob/develop/src/index.ts\nfunction crockfordEncode(input) {\n const output = [];\n let bitsRead = 0;\n let buffer = 0;\n const reversedInput = new Uint8Array(input.slice().reverse());\n for (const byte of reversedInput) {\n buffer |= byte << bitsRead;\n bitsRead += 8;\n while (bitsRead >= 5) {\n output.unshift(buffer & 0x1f);\n buffer >>>= 5;\n bitsRead -= 5;\n }\n }\n if (bitsRead > 0) {\n output.unshift(buffer & 0x1f);\n }\n return output.map(byte => B32_CHARACTERS.charAt(byte)).join(\"\");\n}\nfunction crockfordDecode(input) {\n const sanitizedInput = input.toUpperCase().split(\"\").reverse().join(\"\");\n const output = [];\n let bitsRead = 0;\n let buffer = 0;\n for (const character of sanitizedInput) {\n const byte = B32_CHARACTERS.indexOf(character);\n if (byte === -1) {\n throw new Error(`Invalid base 32 character found in string: ${character}`);\n }\n buffer |= byte << bitsRead;\n bitsRead += 5;\n while (bitsRead >= 8) {\n output.unshift(buffer & 0xff);\n buffer >>>= 8;\n bitsRead -= 8;\n }\n }\n if (bitsRead >= 5 || buffer > 0) {\n output.unshift(buffer & 0xff);\n }\n return new Uint8Array(output);\n}\n/**\n * Fix a ULID's Base32 encoding -\n * i and l (case-insensitive) will be treated as 1 and o (case-insensitive) will be treated as 0.\n * hyphens are ignored during decoding.\n * @param id The ULID\n * @returns The cleaned up ULID\n */\nfunction fixULIDBase32(id) {\n return id.replace(/i/gi, \"1\").replace(/l/gi, \"1\").replace(/o/gi, \"0\").replace(/-/g, \"\");\n}\nfunction incrementBase32(str) {\n let done = undefined, index = str.length, char, charIndex, output = str;\n const maxCharIndex = ENCODING_LEN - 1;\n while (!done && index-- >= 0) {\n char = output[index];\n charIndex = ENCODING.indexOf(char);\n if (charIndex === -1) {\n throw new ULIDError(ULIDErrorCode.Base32IncorrectEncoding, \"Incorrectly encoded string\");\n }\n if (charIndex === maxCharIndex) {\n output = replaceCharAt(output, index, ENCODING[0]);\n continue;\n }\n done = replaceCharAt(output, index, ENCODING[charIndex + 1]);\n }\n if (typeof done === \"string\") {\n return done;\n }\n throw new ULIDError(ULIDErrorCode.Base32IncorrectEncoding, \"Failed incrementing string\");\n}\n\n/**\n * Decode time from a ULID\n * @param id The ULID\n * @returns The decoded timestamp\n */\nfunction decodeTime(id) {\n if (id.length !== TIME_LEN + RANDOM_LEN) {\n throw new ULIDError(ULIDErrorCode.DecodeTimeValueMalformed, \"Malformed ULID\");\n }\n const time = id\n .substr(0, TIME_LEN)\n .toUpperCase()\n .split(\"\")\n .reverse()\n .reduce((carry, char, index) => {\n const encodingIndex = ENCODING.indexOf(char);\n if (encodingIndex === -1) {\n throw new ULIDError(ULIDErrorCode.DecodeTimeInvalidCharacter, `Time decode error: Invalid character: ${char}`);\n }\n return (carry += encodingIndex * Math.pow(ENCODING_LEN, index));\n }, 0);\n if (time > TIME_MAX) {\n throw new ULIDError(ULIDErrorCode.DecodeTimeValueMalformed, `Malformed ULID: timestamp too large: ${time}`);\n }\n return time;\n}\n/**\n * Detect the best PRNG (pseudo-random number generator)\n * @param root The root to check from (global/window)\n * @returns The PRNG function\n */\nfunction detectPRNG(root) {\n const rootLookup = detectRoot();\n const globalCrypto = (rootLookup && (rootLookup.crypto || rootLookup.msCrypto)) ||\n (typeof crypto !== \"undefined\" ? crypto : null);\n if (typeof globalCrypto?.getRandomValues === \"function\") {\n return () => {\n const buffer = new Uint8Array(1);\n globalCrypto.getRandomValues(buffer);\n return buffer[0] / 0xff;\n };\n }\n else if (typeof globalCrypto?.randomBytes === \"function\") {\n return () => globalCrypto.randomBytes(1).readUInt8() / 0xff;\n }\n else if (crypto?.randomBytes) {\n return () => crypto.randomBytes(1).readUInt8() / 0xff;\n }\n throw new ULIDError(ULIDErrorCode.PRNGDetectFailure, \"Failed to find a reliable PRNG\");\n}\nfunction detectRoot() {\n if (inWebWorker())\n return self;\n if (typeof window !== \"undefined\") {\n return window;\n }\n if (typeof global !== \"undefined\") {\n return global;\n }\n if (typeof globalThis !== \"undefined\") {\n return globalThis;\n }\n return null;\n}\nfunction encodeRandom(len, prng) {\n let str = \"\";\n for (; len > 0; len--) {\n str = randomChar(prng) + str;\n }\n return str;\n}\n/**\n * Encode the time portion of a ULID\n * @param now The current timestamp\n * @param len Length to generate\n * @returns The encoded time\n */\nfunction encodeTime(now, len = TIME_LEN) {\n if (isNaN(now)) {\n throw new ULIDError(ULIDErrorCode.EncodeTimeValueMalformed, `Time must be a number: ${now}`);\n }\n else if (now > TIME_MAX) {\n throw new ULIDError(ULIDErrorCode.EncodeTimeSizeExceeded, `Cannot encode a time larger than ${TIME_MAX}: ${now}`);\n }\n else if (now < 0) {\n throw new ULIDError(ULIDErrorCode.EncodeTimeNegative, `Time must be positive: ${now}`);\n }\n else if (Number.isInteger(now) === false) {\n throw new ULIDError(ULIDErrorCode.EncodeTimeValueMalformed, `Time must be an integer: ${now}`);\n }\n let mod, str = \"\";\n for (let currentLen = len; currentLen > 0; currentLen--) {\n mod = now % ENCODING_LEN;\n str = ENCODING.charAt(mod) + str;\n now = (now - mod) / ENCODING_LEN;\n }\n return str;\n}\nfunction inWebWorker() {\n // @ts-ignore\n return typeof WorkerGlobalScope !== \"undefined\" && self instanceof WorkerGlobalScope;\n}\n/**\n * Check if a ULID is valid\n * @param id The ULID to test\n * @returns True if valid, false otherwise\n * @example\n * isValid(\"01HNZX8JGFACFA36RBXDHEQN6E\"); // true\n * isValid(\"\"); // false\n */\nfunction isValid(id) {\n return (typeof id === \"string\" &&\n id.length === TIME_LEN + RANDOM_LEN &&\n id\n .toUpperCase()\n .split(\"\")\n .every(char => ENCODING.indexOf(char) !== -1));\n}\n/**\n * Create a ULID factory to generate monotonically-increasing\n * ULIDs\n * @param prng The PRNG to use\n * @returns A ulid factory\n * @example\n * const ulid = monotonicFactory();\n * ulid(); // \"01HNZXD07M5CEN5XA66EMZSRZW\"\n */\nfunction monotonicFactory(prng) {\n const currentPRNG = prng || detectPRNG();\n let lastTime = 0, lastRandom;\n return function _ulid(seedTime) {\n const seed = !seedTime || isNaN(seedTime) ? Date.now() : seedTime;\n if (seed <= lastTime) {\n const incrementedRandom = (lastRandom = incrementBase32(lastRandom));\n return encodeTime(lastTime, TIME_LEN) + incrementedRandom;\n }\n lastTime = seed;\n const newRandom = (lastRandom = encodeRandom(RANDOM_LEN, currentPRNG));\n return encodeTime(seed, TIME_LEN) + newRandom;\n };\n}\n/**\n * Generate a ULID\n * @param seedTime Optional time seed\n * @param prng Optional PRNG function\n * @returns A ULID string\n * @example\n * ulid(); // \"01HNZXD07M5CEN5XA66EMZSRZW\"\n */\nfunction ulid(seedTime, prng) {\n const currentPRNG = prng || detectPRNG();\n const seed = !seedTime || isNaN(seedTime) ? Date.now() : seedTime;\n return encodeTime(seed, TIME_LEN) + encodeRandom(RANDOM_LEN, currentPRNG);\n}\n\n/**\n * Convert a ULID to a UUID\n * @param ulid The ULID to convert\n * @returns A UUID string\n */\nfunction ulidToUUID(ulid) {\n const isValid = ULID_REGEX.test(ulid);\n if (!isValid) {\n throw new ULIDError(ULIDErrorCode.ULIDInvalid, `Invalid ULID: ${ulid}`);\n }\n const uint8Array = crockfordDecode(ulid);\n let uuid = Array.from(uint8Array)\n .map(byte => byte.toString(16).padStart(2, \"0\"))\n .join(\"\");\n uuid =\n uuid.substring(0, 8) +\n \"-\" +\n uuid.substring(8, 12) +\n \"-\" +\n uuid.substring(12, 16) +\n \"-\" +\n uuid.substring(16, 20) +\n \"-\" +\n uuid.substring(20);\n return uuid.toUpperCase();\n}\n/**\n * Convert a UUID to a ULID\n * @param uuid The UUID to convert\n * @returns A ULID string\n */\nfunction uuidToULID(uuid) {\n const isValid = UUID_REGEX.test(uuid);\n if (!isValid) {\n throw new ULIDError(ULIDErrorCode.UUIDInvalid, `Invalid UUID: ${uuid}`);\n }\n const bytes = uuid.replace(/-/g, \"\").match(/.{1,2}/g);\n if (!bytes) {\n throw new ULIDError(ULIDErrorCode.Unexpected, `Failed parsing UUID bytes: ${uuid}`);\n }\n const uint8Array = new Uint8Array(bytes.map(byte => parseInt(byte, 16)));\n return crockfordEncode(uint8Array);\n}\n\nexport { MAX_ULID, MIN_ULID, TIME_LEN, TIME_MAX, ULIDError, ULIDErrorCode, decodeTime, encodeTime, fixULIDBase32, incrementBase32, isValid, monotonicFactory, ulid, ulidToUUID, uuidToULID };\n", "import validate from './validate.js';\nconst byteToHex = [];\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\nexport function unsafeStringify(arr, offset = 0) {\n return (byteToHex[arr[offset + 0]] +\n byteToHex[arr[offset + 1]] +\n byteToHex[arr[offset + 2]] +\n byteToHex[arr[offset + 3]] +\n '-' +\n byteToHex[arr[offset + 4]] +\n byteToHex[arr[offset + 5]] +\n '-' +\n byteToHex[arr[offset + 6]] +\n byteToHex[arr[offset + 7]] +\n '-' +\n byteToHex[arr[offset + 8]] +\n byteToHex[arr[offset + 9]] +\n '-' +\n byteToHex[arr[offset + 10]] +\n byteToHex[arr[offset + 11]] +\n byteToHex[arr[offset + 12]] +\n byteToHex[arr[offset + 13]] +\n byteToHex[arr[offset + 14]] +\n byteToHex[arr[offset + 15]]).toLowerCase();\n}\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset);\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n return uuid;\n}\nexport default stringify;\n", "import { randomFillSync } from 'crypto';\nconst rnds8Pool = new Uint8Array(256);\nlet poolPtr = rnds8Pool.length;\nexport default function rng() {\n if (poolPtr > rnds8Pool.length - 16) {\n randomFillSync(rnds8Pool);\n poolPtr = 0;\n }\n return rnds8Pool.slice(poolPtr, (poolPtr += 16));\n}\n", "import { randomUUID } from 'crypto';\nexport default { randomUUID };\n", "import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n options = options || {};\n const rnds = options.random ?? options.rng?.() ?? rng();\n if (rnds.length < 16) {\n throw new Error('Random bytes length must be >= 16');\n }\n rnds[6] = (rnds[6] & 0x0f) | 0x40;\n rnds[8] = (rnds[8] & 0x3f) | 0x80;\n if (buf) {\n offset = offset || 0;\n if (offset < 0 || offset + 16 > buf.length) {\n throw new RangeError(`UUID byte range ${offset}:${offset + 15} is out of buffer bounds`);\n }\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n return buf;\n }\n return unsafeStringify(rnds);\n}\nexport default v4;\n", "import rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\nconst _state = {};\nfunction v7(options, buf, offset) {\n let bytes;\n if (options) {\n bytes = v7Bytes(options.random ?? options.rng?.() ?? rng(), options.msecs, options.seq, buf, offset);\n }\n else {\n const now = Date.now();\n const rnds = rng();\n updateV7State(_state, now, rnds);\n bytes = v7Bytes(rnds, _state.msecs, _state.seq, buf, offset);\n }\n return buf ?? unsafeStringify(bytes);\n}\nexport function updateV7State(state, now, rnds) {\n state.msecs ??= -Infinity;\n state.seq ??= 0;\n if (now > state.msecs) {\n state.seq = (rnds[6] << 23) | (rnds[7] << 16) | (rnds[8] << 8) | rnds[9];\n state.msecs = now;\n }\n else {\n state.seq = (state.seq + 1) | 0;\n if (state.seq === 0) {\n state.msecs++;\n }\n }\n return state;\n}\nfunction v7Bytes(rnds, msecs, seq, buf, offset = 0) {\n if (rnds.length < 16) {\n throw new Error('Random bytes length must be >= 16');\n }\n if (!buf) {\n buf = new Uint8Array(16);\n offset = 0;\n }\n else {\n if (offset < 0 || offset + 16 > buf.length) {\n throw new RangeError(`UUID byte range ${offset}:${offset + 15} is out of buffer bounds`);\n }\n }\n msecs ??= Date.now();\n seq ??= ((rnds[6] * 0x7f) << 24) | (rnds[7] << 16) | (rnds[8] << 8) | rnds[9];\n buf[offset++] = (msecs / 0x10000000000) & 0xff;\n buf[offset++] = (msecs / 0x100000000) & 0xff;\n buf[offset++] = (msecs / 0x1000000) & 0xff;\n buf[offset++] = (msecs / 0x10000) & 0xff;\n buf[offset++] = (msecs / 0x100) & 0xff;\n buf[offset++] = msecs & 0xff;\n buf[offset++] = 0x70 | ((seq >>> 28) & 0x0f);\n buf[offset++] = (seq >>> 20) & 0xff;\n buf[offset++] = 0x80 | ((seq >>> 14) & 0x3f);\n buf[offset++] = (seq >>> 6) & 0xff;\n buf[offset++] = ((seq << 2) & 0xff) | (rnds[10] & 0x03);\n buf[offset++] = rnds[11];\n buf[offset++] = rnds[12];\n buf[offset++] = rnds[13];\n buf[offset++] = rnds[14];\n buf[offset++] = rnds[15];\n return buf;\n}\nexport default v7;\n", "import { InMemoryOps, Pagination } from '../query-plan'\nimport { doKeysMatch } from '../utils'\n\nexport function processRecords(value: unknown, ops: InMemoryOps): unknown {\n if (value == null) {\n return value\n }\n\n if (typeof value === 'string') {\n return processRecords(JSON.parse(value), ops)\n }\n\n if (Array.isArray(value)) {\n return processManyRecords(value as Record<string, unknown>[], ops)\n }\n\n return processOneRecord(value as Record<string, unknown>, ops)\n}\n\nfunction processOneRecord(record: Record<string, unknown>, ops: InMemoryOps): Record<string, unknown> | null {\n if (ops.pagination) {\n const { skip, take, cursor } = ops.pagination\n if (skip !== null && skip > 0) {\n return null\n }\n if (take === 0) {\n return null\n }\n if (cursor !== null && !doKeysMatch(record, cursor)) {\n return null\n }\n }\n return processNestedRecords(record, ops.nested)\n}\n\nfunction processNestedRecords(\n record: Record<string, unknown>,\n opsMap: Record<string, InMemoryOps>,\n): Record<string, unknown> {\n for (const [key, ops] of Object.entries(opsMap)) {\n record[key] = processRecords(record[key], ops)\n }\n return record\n}\n\nfunction processManyRecords(records: Record<string, unknown>[], ops: InMemoryOps): Record<string, unknown>[] {\n if (ops.distinct !== null) {\n const fields = ops.linkingFields !== null ? [...ops.distinct, ...ops.linkingFields] : ops.distinct\n records = distinctBy(records, fields)\n }\n\n if (ops.pagination) {\n records = paginate(records, ops.pagination, ops.linkingFields)\n }\n\n if (ops.reverse) {\n records.reverse()\n }\n\n if (Object.keys(ops.nested).length === 0) {\n return records\n }\n\n return records.map((record) => processNestedRecords(record, ops.nested))\n}\n\nfunction distinctBy(records: Record<string, unknown>[], fields: string[]): Record<string, unknown>[] {\n const seen = new Set()\n const result: Record<string, unknown>[] = []\n for (const record of records) {\n const key = getRecordKey(record, fields)\n if (!seen.has(key)) {\n seen.add(key)\n result.push(record)\n }\n }\n return result\n}\n\nfunction paginate(records: {}[], pagination: Pagination, linkingFields: string[] | null): {}[] {\n if (linkingFields === null) {\n return paginateSingleList(records, pagination)\n }\n\n const groupedByParent = new Map<string, {}[]>()\n for (const record of records) {\n const parentKey = getRecordKey(record, linkingFields)\n if (!groupedByParent.has(parentKey)) {\n groupedByParent.set(parentKey, [])\n }\n groupedByParent.get(parentKey)!.push(record)\n }\n\n const groupList = Array.from(groupedByParent.entries())\n groupList.sort(([aId], [bId]) => (aId < bId ? -1 : aId > bId ? 1 : 0))\n\n return groupList.flatMap(([, elems]) => paginateSingleList(elems, pagination))\n}\n\nfunction paginateSingleList(list: {}[], { cursor, skip, take }: Pagination): {}[] {\n const cursorIndex = cursor !== null ? list.findIndex((item) => doKeysMatch(item, cursor)) : 0\n if (cursorIndex === -1) {\n return []\n }\n const start = cursorIndex + (skip ?? 0)\n const end = take !== null ? start + take : list.length\n\n return list.slice(start, end)\n}\n\n/*\n * Generate a key string for a record based on the values of the specified fields.\n */\nexport function getRecordKey(record: {}, fields: string[]): string {\n return JSON.stringify(fields.map((field) => record[field]))\n}\n", "import { ArgType, Arity } from '@prisma/driver-adapter-utils'\n\nexport type PrismaValuePlaceholder = { prisma__type: 'param'; prisma__value: { name: string; type: string } }\n\nexport function isPrismaValuePlaceholder(value: unknown): value is PrismaValuePlaceholder {\n return typeof value === 'object' && value !== null && value['prisma__type'] === 'param'\n}\n\nexport type PrismaValueGenerator = {\n prisma__type: 'generatorCall'\n prisma__value: { name: string; args: PrismaValue[] }\n}\n\nexport function isPrismaValueGenerator(value: unknown): value is PrismaValueGenerator {\n return typeof value === 'object' && value !== null && value['prisma__type'] === 'generatorCall'\n}\n\nexport type PrismaValue =\n | string\n | boolean\n | number\n | PrismaValue[]\n | null\n | Record<string, unknown>\n | PrismaValuePlaceholder\n | PrismaValueGenerator\n\nexport type ResultNode =\n | {\n type: 'affectedRows'\n }\n | {\n type: 'object'\n fields: Record<string, ResultNode>\n serializedName: string | null\n skipNulls: boolean\n }\n | {\n type: 'field'\n dbName: string\n fieldType: FieldType\n }\n\nexport type QueryPlanBinding = {\n name: string\n expr: QueryPlanNode\n}\n\nexport type QueryPlanDbQuery =\n | {\n type: 'rawSql'\n sql: string\n args: PrismaValue[]\n argTypes: ArgType[]\n }\n | {\n type: 'templateSql'\n fragments: Fragment[]\n placeholderFormat: PlaceholderFormat\n args: PrismaValue[]\n argTypes: DynamicArgType[]\n chunkable: boolean\n }\n\nexport type DynamicArgType = ArgType | { arity: 'tuple'; elements: ArgType[] }\n\nexport type Fragment =\n | { type: 'stringChunk'; chunk: string }\n | { type: 'parameter' }\n | { type: 'parameterTuple' }\n | {\n type: 'parameterTupleList'\n itemPrefix: string\n itemSeparator: string\n itemSuffix: string\n groupSeparator: string\n }\n\nexport interface PlaceholderFormat {\n prefix: string\n hasNumbering: boolean\n}\n\nexport type JoinExpression = {\n child: QueryPlanNode\n on: [left: string, right: string][]\n parentField: string\n isRelationUnique: boolean\n}\n\nexport type QueryPlanNode =\n | {\n type: 'value'\n args: PrismaValue\n }\n | {\n type: 'seq'\n args: QueryPlanNode[]\n }\n | {\n type: 'get'\n args: {\n name: string\n }\n }\n | {\n type: 'let'\n args: {\n bindings: QueryPlanBinding[]\n expr: QueryPlanNode\n }\n }\n | {\n type: 'getFirstNonEmpty'\n args: {\n names: string[]\n }\n }\n | {\n type: 'query'\n args: QueryPlanDbQuery\n }\n | {\n type: 'execute'\n args: QueryPlanDbQuery\n }\n | {\n type: 'reverse'\n args: QueryPlanNode\n }\n | {\n type: 'sum'\n args: QueryPlanNode[]\n }\n | {\n type: 'concat'\n args: QueryPlanNode[]\n }\n | {\n type: 'unique'\n args: QueryPlanNode\n }\n | {\n type: 'required'\n args: QueryPlanNode\n }\n | {\n type: 'join'\n args: {\n parent: QueryPlanNode\n children: JoinExpression[]\n }\n }\n | {\n type: 'mapField'\n args: {\n field: string\n records: QueryPlanNode\n }\n }\n | {\n type: 'transaction'\n args: QueryPlanNode\n }\n | {\n type: 'dataMap'\n args: {\n expr: QueryPlanNode\n structure: ResultNode\n enums: Record<string, Record<string, string>>\n }\n }\n | {\n type: 'validate'\n args: {\n expr: QueryPlanNode\n rules: DataRule[]\n } & ValidationError\n }\n | {\n type: 'if'\n args: {\n value: QueryPlanNode\n rule: DataRule\n then: QueryPlanNode\n else: QueryPlanNode\n }\n }\n | {\n type: 'unit'\n }\n | {\n type: 'diff'\n args: {\n from: QueryPlanNode\n to: QueryPlanNode\n fields: string[]\n }\n }\n | {\n type: 'initializeRecord'\n args: {\n expr: QueryPlanNode\n fields: Record<string, FieldInitializer>\n }\n }\n | {\n type: 'mapRecord'\n args: {\n expr: QueryPlanNode\n fields: Record<string, FieldOperation>\n }\n }\n | {\n type: 'process'\n args: {\n expr: QueryPlanNode\n operations: InMemoryOps\n }\n }\n\nexport type FieldInitializer = { type: 'value'; value: PrismaValue } | { type: 'lastInsertId' }\n\nexport type FieldOperation =\n | { type: 'set'; value: PrismaValue }\n | { type: 'add'; value: PrismaValue }\n | { type: 'subtract'; value: PrismaValue }\n | { type: 'multiply'; value: PrismaValue }\n | { type: 'divide'; value: PrismaValue }\n\nexport type Pagination = {\n cursor: Record<string, PrismaValue> | null\n take: number | null\n skip: number | null\n}\n\nexport type InMemoryOps = {\n pagination: Pagination | null\n distinct: string[] | null\n reverse: boolean\n linkingFields: string[] | null\n nested: Record<string, InMemoryOps>\n}\n\nexport type DataRule =\n | {\n type: 'rowCountEq'\n args: number\n }\n | {\n type: 'rowCountNeq'\n args: number\n }\n | {\n type: 'affectedRowCountEq'\n args: number\n }\n | {\n type: 'never'\n }\n\nexport type ValidationError =\n | {\n error_identifier: 'RELATION_VIOLATION'\n context: {\n relation: string\n modelA: string\n modelB: string\n }\n }\n | {\n error_identifier: 'MISSING_RELATED_RECORD'\n context: {\n model: string\n relation: string\n relationType: string\n operation: string\n neededFor?: string\n }\n }\n | {\n error_identifier: 'MISSING_RECORD'\n context: {\n operation: string\n }\n }\n | {\n error_identifier: 'INCOMPLETE_CONNECT_INPUT'\n context: {\n expectedRows: number\n }\n }\n | {\n error_identifier: 'INCOMPLETE_CONNECT_OUTPUT'\n context: {\n expectedRows: number\n relation: string\n relationType: string\n }\n }\n | {\n error_identifier: 'RECORDS_NOT_CONNECTED'\n context: {\n relation: string\n parent: string\n child: string\n }\n }\n\nexport type FieldType = { arity: Arity } & FieldScalarType\n\nexport type FieldScalarType =\n | {\n type:\n | 'string'\n | 'int'\n | 'bigint'\n | 'float'\n | 'boolean'\n | 'json'\n | 'object'\n | 'datetime'\n | 'decimal'\n | 'unsupported'\n }\n | { type: 'enum'; name: string }\n | { type: 'bytes'; encoding: 'array' | 'base64' | 'hex' }\n", "import { ArgType, SqlQuery } from '@prisma/driver-adapter-utils'\n\nimport {\n DynamicArgType,\n type Fragment,\n isPrismaValueGenerator,\n isPrismaValuePlaceholder,\n type PlaceholderFormat,\n type PrismaValueGenerator,\n type PrismaValuePlaceholder,\n type QueryPlanDbQuery,\n} from '../query-plan'\nimport { UserFacingError } from '../user-facing-error'\nimport { assertNever } from '../utils'\nimport { GeneratorRegistrySnapshot } from './generators'\nimport { ScopeBindings } from './scope'\n\nexport function renderQuery(\n dbQuery: QueryPlanDbQuery,\n scope: ScopeBindings,\n generators: GeneratorRegistrySnapshot,\n maxChunkSize?: number,\n): SqlQuery[] {\n const args = dbQuery.args.map((arg) => evaluateArg(arg, scope, generators))\n\n switch (dbQuery.type) {\n case 'rawSql':\n return [renderRawSql(dbQuery.sql, args, dbQuery.argTypes)]\n case 'templateSql': {\n const chunks = dbQuery.chunkable ? chunkParams(dbQuery.fragments, args, maxChunkSize) : [args]\n return chunks.map((params) => {\n if (maxChunkSize !== undefined && params.length > maxChunkSize) {\n throw new UserFacingError('The query parameter limit supported by your database is exceeded.', 'P2029')\n }\n\n return renderTemplateSql(dbQuery.fragments, dbQuery.placeholderFormat, params, dbQuery.argTypes)\n })\n }\n default:\n assertNever(dbQuery['type'], `Invalid query type`)\n }\n}\n\nexport function evaluateArg(arg: unknown, scope: ScopeBindings, generators: GeneratorRegistrySnapshot): unknown {\n while (doesRequireEvaluation(arg)) {\n if (isPrismaValuePlaceholder(arg)) {\n const found = scope[arg.prisma__value.name]\n if (found === undefined) {\n throw new Error(`Missing value for query variable ${arg.prisma__value.name}`)\n }\n arg = found\n } else if (isPrismaValueGenerator(arg)) {\n const { name, args } = arg.prisma__value\n const generator = generators[name]\n if (!generator) {\n throw new Error(`Encountered an unknown generator '${name}'`)\n }\n arg = generator.generate(...args.map((arg) => evaluateArg(arg, scope, generators)))\n } else {\n assertNever(arg, `Unexpected unevaluated value type: ${arg}`)\n }\n }\n\n if (Array.isArray(arg)) {\n arg = arg.map((el) => evaluateArg(el, scope, generators))\n }\n\n return arg\n}\n\nfunction renderTemplateSql(\n fragments: Fragment[],\n placeholderFormat: PlaceholderFormat,\n params: unknown[],\n argTypes: DynamicArgType[],\n): SqlQuery {\n let sql = ''\n const ctx = { placeholderNumber: 1 }\n const flattenedParams: unknown[] = []\n const flattenedArgTypes: ArgType[] = []\n\n for (const fragment of pairFragmentsWithParams(fragments, params, argTypes)) {\n sql += renderFragment(fragment, placeholderFormat, ctx)\n if (fragment.type === 'stringChunk') {\n continue\n }\n const length = flattenedParams.length\n const added = flattenedParams.push(...flattenedFragmentParams(fragment)) - length\n\n if (fragment.argType.arity === 'tuple') {\n if (added % fragment.argType.elements.length !== 0) {\n throw new Error(\n `Malformed query template. Expected the number of parameters to match the tuple arity, but got ${added} parameters for a tuple of arity ${fragment.argType.elements.length}.`,\n )\n }\n // If we have a tuple, we just expand its elements repeatedly.\n for (let i = 0; i < added / fragment.argType.elements.length; i++) {\n flattenedArgTypes.push(...fragment.argType.elements)\n }\n } else {\n // If we have a non-tuple, we just expand the single type repeatedly.\n for (let i = 0; i < added; i++) {\n flattenedArgTypes.push(fragment.argType)\n }\n }\n }\n\n return {\n sql,\n args: flattenedParams,\n argTypes: flattenedArgTypes,\n }\n}\n\nfunction renderFragment<Type extends DynamicArgType | undefined>(\n fragment: FragmentWithParams<Type>,\n placeholderFormat: PlaceholderFormat,\n ctx: { placeholderNumber: number },\n): string {\n const fragmentType = fragment.type\n switch (fragmentType) {\n case 'parameter':\n return formatPlaceholder(placeholderFormat, ctx.placeholderNumber++)\n\n case 'stringChunk':\n return fragment.chunk\n\n case 'parameterTuple': {\n const placeholders =\n fragment.value.length == 0\n ? 'NULL'\n : fragment.value.map(() => formatPlaceholder(placeholderFormat, ctx.placeholderNumber++)).join(',')\n return `(${placeholders})`\n }\n\n case 'parameterTupleList': {\n return fragment.value\n .map((tuple) => {\n const elements = tuple\n .map(() => formatPlaceholder(placeholderFormat, ctx.placeholderNumber++))\n .join(fragment.itemSeparator)\n return `${fragment.itemPrefix}${elements}${fragment.itemSuffix}`\n })\n .join(fragment.groupSeparator)\n }\n\n default:\n assertNever(fragmentType, 'Invalid fragment type')\n }\n}\n\nfunction formatPlaceholder(placeholderFormat: PlaceholderFormat, placeholderNumber: number): string {\n return placeholderFormat.hasNumbering ? `${placeholderFormat.prefix}${placeholderNumber}` : placeholderFormat.prefix\n}\n\nfunction renderRawSql(sql: string, args: unknown[], argTypes: ArgType[]): SqlQuery {\n return {\n sql,\n args: args,\n argTypes,\n }\n}\n\nfunction doesRequireEvaluation(param: unknown): param is PrismaValuePlaceholder | PrismaValueGenerator {\n return isPrismaValuePlaceholder(param) || isPrismaValueGenerator(param)\n}\n\ntype FragmentWithParams<Type extends DynamicArgType | undefined = undefined> = Fragment &\n (\n | { type: 'stringChunk' }\n | { type: 'parameter'; value: unknown; argType: Type }\n | { type: 'parameterTuple'; value: unknown[]; argType: Type }\n | { type: 'parameterTupleList'; value: unknown[][]; argType: Type }\n )\n\nfunction* pairFragmentsWithParams<Types>(\n fragments: Fragment[],\n params: unknown[],\n argTypes: Types,\n): Generator<FragmentWithParams<Types extends DynamicArgType[] ? DynamicArgType : undefined>> {\n let index = 0\n\n for (const fragment of fragments) {\n switch (fragment.type) {\n case 'parameter': {\n if (index >= params.length) {\n throw new Error(`Malformed query template. Fragments attempt to read over ${params.length} parameters.`)\n }\n\n yield { ...fragment, value: params[index], argType: argTypes?.[index] }\n index++\n break\n }\n\n case 'stringChunk': {\n yield fragment\n break\n }\n\n case 'parameterTuple': {\n if (index >= params.length) {\n throw new Error(`Malformed query template. Fragments attempt to read over ${params.length} parameters.`)\n }\n\n const value = params[index]\n yield { ...fragment, value: Array.isArray(value) ? value : [value], argType: argTypes?.[index] }\n index++\n break\n }\n\n case 'parameterTupleList': {\n if (index >= params.length) {\n throw new Error(`Malformed query template. Fragments attempt to read over ${params.length} parameters.`)\n }\n\n const value = params[index]\n if (!Array.isArray(value)) {\n throw new Error(`Malformed query template. Tuple list expected.`)\n }\n if (value.length === 0) {\n throw new Error(`Malformed query template. Tuple list cannot be empty.`)\n }\n for (const tuple of value) {\n if (!Array.isArray(tuple)) {\n throw new Error(`Malformed query template. Tuple expected.`)\n }\n }\n\n yield { ...fragment, value, argType: argTypes?.[index] }\n index++\n break\n }\n }\n }\n}\n\nfunction* flattenedFragmentParams<Type extends DynamicArgType | undefined>(\n fragment: FragmentWithParams<Type>,\n): Generator<unknown, undefined, undefined> {\n switch (fragment.type) {\n case 'parameter':\n yield fragment.value\n break\n case 'stringChunk':\n break\n case 'parameterTuple':\n yield* fragment.value\n break\n case 'parameterTupleList':\n for (const tuple of fragment.value) {\n yield* tuple\n }\n break\n }\n}\n\nfunction chunkParams(fragments: Fragment[], params: unknown[], maxChunkSize?: number): unknown[][] {\n // Find out the total number of parameters once flattened and what the maximum number of\n // parameters in a single fragment is.\n let totalParamCount = 0\n let maxParamsPerFragment = 0\n for (const fragment of pairFragmentsWithParams(fragments, params, undefined)) {\n let paramSize = 0\n for (const _ of flattenedFragmentParams(fragment)) {\n void _\n paramSize++\n }\n maxParamsPerFragment = Math.max(maxParamsPerFragment, paramSize)\n totalParamCount += paramSize\n }\n\n let chunkedParams: unknown[][] = [[]]\n for (const fragment of pairFragmentsWithParams(fragments, params, undefined)) {\n switch (fragment.type) {\n case 'parameter': {\n for (const params of chunkedParams) {\n params.push(fragment.value)\n }\n break\n }\n\n case 'stringChunk': {\n break\n }\n\n case 'parameterTuple': {\n const thisParamCount = fragment.value.length\n let chunks: unknown[][] = []\n\n if (\n maxChunkSize &&\n // Have we split the parameters into chunks already?\n chunkedParams.length === 1 &&\n // Is this the fragment that has the most parameters?\n thisParamCount === maxParamsPerFragment &&\n // Do we need chunking to fit the parameters?\n totalParamCount > maxChunkSize &&\n // Would chunking enable us to fit the parameters?\n totalParamCount - thisParamCount < maxChunkSize\n ) {\n const availableSize = maxChunkSize - (totalParamCount - thisParamCount)\n chunks = chunkArray(fragment.value, availableSize)\n } else {\n chunks = [fragment.value]\n }\n\n chunkedParams = chunkedParams.flatMap((params) => chunks.map((chunk) => [...params, chunk]))\n break\n }\n\n case 'parameterTupleList': {\n const thisParamCount = fragment.value.reduce((acc, tuple) => acc + tuple.length, 0)\n\n const completeChunks: unknown[][][] = []\n let currentChunk: unknown[][] = []\n let currentChunkParamCount = 0\n\n for (const tuple of fragment.value) {\n if (\n maxChunkSize &&\n // Have we split the parameters into chunks already?\n chunkedParams.length === 1 &&\n // Is this the fragment that has the most parameters?\n thisParamCount === maxParamsPerFragment &&\n // Is there anything in the current chunk?\n currentChunk.length > 0 &&\n // Will adding this tuple exceed the max chunk size?\n totalParamCount - thisParamCount + currentChunkParamCount + tuple.length > maxChunkSize\n ) {\n completeChunks.push(currentChunk)\n currentChunk = []\n currentChunkParamCount = 0\n }\n currentChunk.push(tuple)\n currentChunkParamCount += tuple.length\n }\n\n if (currentChunk.length > 0) {\n completeChunks.push(currentChunk)\n }\n\n chunkedParams = chunkedParams.flatMap((params) => completeChunks.map((chunk) => [...params, chunk]))\n break\n }\n }\n }\n\n return chunkedParams\n}\n\nfunction chunkArray<T>(array: T[], chunkSize: number): T[][] {\n const result: T[][] = []\n for (let i = 0; i < array.length; i += chunkSize) {\n result.push(array.slice(i, i + chunkSize))\n }\n return result\n}\n", "import { type ColumnType, ColumnTypeEnum, type SqlResultSet } from '@prisma/driver-adapter-utils'\n\nimport { assertNever } from '../utils'\n\nexport function serializeSql(resultSet: SqlResultSet): Record<string, unknown>[] {\n return resultSet.rows.map((row) =>\n row.reduce<Record<string, unknown>>((acc, value, index) => {\n acc[resultSet.columnNames[index]] = value\n return acc\n }, {}),\n )\n}\n\nexport function serializeRawSql(resultSet: SqlResultSet): Record<string, unknown> {\n return {\n columns: resultSet.columnNames,\n types: resultSet.columnTypes.map((type) => serializeColumnType(type)),\n rows: resultSet.rows.map((row) =>\n row.map((value, index) => serializeRawValue(value, resultSet.columnTypes[index])),\n ),\n }\n}\n\nfunction serializeRawValue(value: unknown, type: ColumnType): unknown {\n if (value === null) {\n return null\n }\n\n switch (type) {\n case ColumnTypeEnum.Int32:\n switch (typeof value) {\n case 'number':\n return Math.trunc(value)\n case 'string':\n return Math.trunc(Number(value))\n default:\n throw new Error(`Cannot serialize value of type ${typeof value} as Int32`)\n }\n\n case ColumnTypeEnum.Int32Array:\n if (!Array.isArray(value)) {\n throw new Error(`Cannot serialize value of type ${typeof value} as Int32Array`)\n }\n return value.map((v) => serializeRawValue(v, ColumnTypeEnum.Int32))\n\n case ColumnTypeEnum.Int64:\n switch (typeof value) {\n case 'number':\n return BigInt(Math.trunc(value))\n case 'string':\n return value\n default:\n throw new Error(`Cannot serialize value of type ${typeof value} as Int64`)\n }\n\n case ColumnTypeEnum.Int64Array:\n if (!Array.isArray(value)) {\n throw new Error(`Cannot serialize value of type ${typeof value} as Int64Array`)\n }\n return value.map((v) => serializeRawValue(v, ColumnTypeEnum.Int64))\n\n case ColumnTypeEnum.Json:\n switch (typeof value) {\n case 'string':\n return JSON.parse(value)\n default:\n throw new Error(`Cannot serialize value of type ${typeof value} as Json`)\n }\n\n case ColumnTypeEnum.JsonArray:\n if (!Array.isArray(value)) {\n throw new Error(`Cannot serialize value of type ${typeof value} as JsonArray`)\n }\n return value.map((v) => serializeRawValue(v, ColumnTypeEnum.Json))\n\n case ColumnTypeEnum.Boolean:\n switch (typeof value) {\n case 'boolean':\n return value\n case 'string':\n return value === 'true' || value === '1'\n case 'number':\n return value === 1\n default:\n throw new Error(`Cannot serialize value of type ${typeof value} as Boolean`)\n }\n\n case ColumnTypeEnum.BooleanArray:\n if (!Array.isArray(value)) {\n throw new Error(`Cannot serialize value of type ${typeof value} as BooleanArray`)\n }\n return value.map((v) => serializeRawValue(v, ColumnTypeEnum.Boolean))\n\n default:\n return value // For all other types, return the value as is\n }\n}\n\n// maps JS column types to their Rust equivalents\nfunction serializeColumnType(columnType: ColumnType): string {\n switch (columnType) {\n case ColumnTypeEnum.Int32:\n return 'int'\n case ColumnTypeEnum.Int64:\n return 'bigint'\n case ColumnTypeEnum.Float:\n return 'float'\n case ColumnTypeEnum.Double:\n return 'double'\n case ColumnTypeEnum.Text:\n return 'string'\n case ColumnTypeEnum.Enum:\n return 'enum'\n case ColumnTypeEnum.Bytes:\n return 'bytes'\n case ColumnTypeEnum.Boolean:\n return 'bool'\n case ColumnTypeEnum.Character:\n return 'char'\n case ColumnTypeEnum.Numeric:\n return 'decimal'\n case ColumnTypeEnum.Json:\n return 'json'\n case ColumnTypeEnum.Uuid:\n return 'uuid'\n case ColumnTypeEnum.DateTime:\n return 'datetime'\n case ColumnTypeEnum.Date:\n return 'date'\n case ColumnTypeEnum.Time:\n return 'time'\n case ColumnTypeEnum.Int32Array:\n return 'int-array'\n case ColumnTypeEnum.Int64Array:\n return 'bigint-array'\n case ColumnTypeEnum.FloatArray:\n return 'float-array'\n case ColumnTypeEnum.DoubleArray:\n return 'double-array'\n case ColumnTypeEnum.TextArray:\n return 'string-array'\n case ColumnTypeEnum.EnumArray:\n return 'string-array'\n case ColumnTypeEnum.BytesArray:\n return 'bytes-array'\n case ColumnTypeEnum.BooleanArray:\n return 'bool-array'\n case ColumnTypeEnum.CharacterArray:\n return 'char-array'\n case ColumnTypeEnum.NumericArray:\n return 'decimal-array'\n case ColumnTypeEnum.JsonArray:\n return 'json-array'\n case ColumnTypeEnum.UuidArray:\n return 'uuid-array'\n case ColumnTypeEnum.DateTimeArray:\n return 'datetime-array'\n case ColumnTypeEnum.DateArray:\n return 'date-array'\n case ColumnTypeEnum.TimeArray:\n return 'time-array'\n case ColumnTypeEnum.UnknownNumber:\n return 'unknown'\n /// The following PlanetScale type IDs are mapped into Set:\n /// - SET (SET) -> e.g. `\"foo,bar\"` (String-encoded, comma-separated)\n case ColumnTypeEnum.Set:\n return 'string'\n default:\n assertNever(columnType, `Unexpected column type: ${columnType}`)\n }\n}\n", "import { DataRule, ValidationError } from '../query-plan'\nimport { UserFacingError } from '../user-facing-error'\nimport { assertNever } from '../utils'\n\nexport function performValidation(data: unknown, rules: DataRule[], error: ValidationError) {\n if (!rules.every((rule) => doesSatisfyRule(data, rule))) {\n const message = renderMessage(data, error)\n const code = getErrorCode(error)\n throw new UserFacingError(message, code, error.context)\n }\n}\n\nexport function doesSatisfyRule(data: unknown, rule: DataRule): boolean {\n switch (rule.type) {\n case 'rowCountEq':\n if (Array.isArray(data)) {\n return data.length === rule.args\n }\n if (data === null) {\n return rule.args === 0\n }\n return rule.args === 1\n\n case 'rowCountNeq':\n if (Array.isArray(data)) {\n return data.length !== rule.args\n }\n if (data === null) {\n return rule.args !== 0\n }\n return rule.args !== 1\n\n case 'affectedRowCountEq':\n return data === rule.args\n\n case 'never':\n return false\n\n default:\n assertNever(rule, `Unknown rule type: ${(rule as DataRule).type}`)\n }\n}\n\nfunction renderMessage(data: unknown, error: ValidationError): string {\n switch (error.error_identifier) {\n case 'RELATION_VIOLATION':\n return `The change you are trying to make would violate the required relation '${error.context.relation}' between the \\`${error.context.modelA}\\` and \\`${error.context.modelB}\\` models.`\n case 'MISSING_RECORD':\n return `An operation failed because it depends on one or more records that were required but not found. No record was found for ${error.context.operation}.`\n case 'MISSING_RELATED_RECORD': {\n const hint = error.context.neededFor ? ` (needed to ${error.context.neededFor})` : ''\n return `An operation failed because it depends on one or more records that were required but not found. No '${error.context.model}' record${hint} was found for ${error.context.operation} on ${error.context.relationType} relation '${error.context.relation}'.`\n }\n case 'INCOMPLETE_CONNECT_INPUT':\n return `An operation failed because it depends on one or more records that were required but not found. Expected ${\n error.context.expectedRows\n } records to be connected, found only ${Array.isArray(data) ? data.length : data}.`\n case 'INCOMPLETE_CONNECT_OUTPUT':\n return `The required connected records were not found. Expected ${\n error.context.expectedRows\n } records to be connected after connect operation on ${error.context.relationType} relation '${\n error.context.relation\n }', found ${Array.isArray(data) ? data.length : data}.`\n case 'RECORDS_NOT_CONNECTED':\n return `The records for relation \\`${error.context.relation}\\` between the \\`${error.context.parent}\\` and \\`${error.context.child}\\` models are not connected.`\n\n default:\n assertNever(error, `Unknown error identifier: ${error}`)\n }\n}\n\nfunction getErrorCode(error: ValidationError): string {\n switch (error.error_identifier) {\n case 'RELATION_VIOLATION':\n return 'P2014'\n case 'RECORDS_NOT_CONNECTED':\n return 'P2017'\n case 'INCOMPLETE_CONNECT_OUTPUT':\n return 'P2018'\n case 'MISSING_RECORD':\n case 'MISSING_RELATED_RECORD':\n case 'INCOMPLETE_CONNECT_INPUT':\n return 'P2025'\n\n default:\n assertNever(error, `Unknown error identifier: ${error}`)\n }\n}\n", "import { ConnectionInfo, SqlQuery, SqlQueryable, SqlResultSet } from '@prisma/driver-adapter-utils'\nimport type { SqlCommenterPlugin, SqlCommenterQueryInfo } from '@prisma/sqlcommenter'\n\nimport { QueryEvent } from '../events'\nimport { FieldInitializer, FieldOperation, JoinExpression, QueryPlanNode } from '../query-plan'\nimport { type SchemaProvider } from '../schema'\nimport { appendSqlComment, buildSqlComment } from '../sql-commenter'\nimport { type TracingHelper, withQuerySpanAndEvent } from '../tracing'\nimport { type TransactionManager } from '../transaction-manager/transaction-manager'\nimport { rethrowAsUserFacing, rethrowAsUserFacingRawError } from '../user-facing-error'\nimport { assertNever } from '../utils'\nimport { applyDataMap } from './data-mapper'\nimport { GeneratorRegistry, GeneratorRegistrySnapshot } from './generators'\nimport { getRecordKey, processRecords } from './in-memory-processing'\nimport { evaluateArg, renderQuery } from './render-query'\nimport { PrismaObject, ScopeBindings, Value } from './scope'\nimport { serializeRawSql, serializeSql } from './serialize-sql'\nimport { doesSatisfyRule, performValidation } from './validation'\n\nexport type QueryInterpreterTransactionManager = { enabled: true; manager: TransactionManager } | { enabled: false }\n\nexport type QueryInterpreterOptions = {\n onQuery?: (event: QueryEvent) => void\n tracingHelper: TracingHelper\n serializer: (results: SqlResultSet) => Value\n rawSerializer?: (results: SqlResultSet) => Value\n provider?: SchemaProvider\n connectionInfo?: ConnectionInfo\n}\n\nexport type QueryRuntimeOptions = {\n queryable: SqlQueryable\n transactionManager: QueryInterpreterTransactionManager\n scope: Record<string, unknown>\n sqlCommenter?: QueryInterpreterSqlCommenter\n}\n\ntype QueryRuntimeContext = {\n queryable: SqlQueryable\n transactionManager: QueryInterpreterTransactionManager\n scope: Record<string, unknown>\n generators: GeneratorRegistrySnapshot\n sqlCommenter?: QueryInterpreterSqlCommenter\n}\n\nexport type QueryInterpreterSqlCommenter = {\n plugins: SqlCommenterPlugin[]\n queryInfo: SqlCommenterQueryInfo\n}\n\nexport class QueryInterpreter {\n readonly #onQuery?: (event: QueryEvent) => void\n readonly #generators: GeneratorRegistry = new GeneratorRegistry()\n readonly #tracingHelper: TracingHelper\n readonly #serializer: (results: SqlResultSet) => Value\n readonly #rawSerializer: (results: SqlResultSet) => Value\n readonly #provider?: SchemaProvider\n readonly #connectionInfo?: ConnectionInfo\n\n constructor({\n onQuery,\n tracingHelper,\n serializer,\n rawSerializer,\n provider,\n connectionInfo,\n }: QueryInterpreterOptions) {\n this.#onQuery = onQuery\n this.#tracingHelper = tracingHelper\n this.#serializer = serializer\n this.#rawSerializer = rawSerializer ?? serializer\n this.#provider = provider\n this.#connectionInfo = connectionInfo\n }\n\n static forSql(options: {\n onQuery?: (event: QueryEvent) => void\n tracingHelper: TracingHelper\n provider?: SchemaProvider\n connectionInfo?: ConnectionInfo\n }): QueryInterpreter {\n return new QueryInterpreter({\n onQuery: options.onQuery,\n tracingHelper: options.tracingHelper,\n serializer: serializeSql,\n rawSerializer: serializeRawSql,\n provider: options.provider,\n connectionInfo: options.connectionInfo,\n })\n }\n\n async run(queryPlan: QueryPlanNode, options: QueryRuntimeOptions): Promise<unknown> {\n const { value } = await this.interpretNode(queryPlan, {\n ...options,\n generators: this.#generators.snapshot(),\n }).catch((e) => rethrowAsUserFacing(e))\n\n return value\n }\n\n private async interpretNode(node: QueryPlanNode, context: QueryRuntimeContext): Promise<IntermediateValue> {\n switch (node.type) {\n case 'value': {\n return {\n value: evaluateArg(node.args, context.scope, context.generators),\n }\n }\n\n case 'seq': {\n let result: IntermediateValue | undefined\n for (const arg of node.args) {\n result = await this.interpretNode(arg, context)\n }\n return result ?? { value: undefined }\n }\n\n case 'get': {\n return { value: context.scope[node.args.name] }\n }\n\n case 'let': {\n const nestedScope: ScopeBindings = Object.create(context.scope)\n for (const binding of node.args.bindings) {\n const { value } = await this.interpretNode(binding.expr, { ...context, scope: nestedScope })\n nestedScope[binding.name] = value\n }\n return this.interpretNode(node.args.expr, { ...context, scope: nestedScope })\n }\n\n case 'getFirstNonEmpty': {\n for (const name of node.args.names) {\n const value = context.scope[name]\n if (!isEmpty(value)) {\n return { value }\n }\n }\n return { value: [] }\n }\n\n case 'concat': {\n const parts = await Promise.all(\n node.args.map((arg) => this.interpretNode(arg, context).then((res) => res.value)),\n )\n return {\n value: parts.length > 0 ? parts.reduce<Value[]>((acc, part) => acc.concat(asList(part)), []) : [],\n }\n }\n\n case 'sum': {\n const parts = await Promise.all(\n node.args.map((arg) => this.interpretNode(arg, context).then((res) => res.value)),\n )\n return {\n value: parts.length > 0 ? parts.reduce((acc, part) => asNumber(acc) + asNumber(part)) : 0,\n }\n }\n\n case 'execute': {\n const queries = renderQuery(node.args, context.scope, context.generators, this.#maxChunkSize())\n\n let sum = 0\n for (const query of queries) {\n const commentedQuery = applyComments(query, context.sqlCommenter)\n sum += await this.#withQuerySpanAndEvent(commentedQuery, context.queryable, () =>\n context.queryable\n .executeRaw(commentedQuery)\n .catch((err) =>\n node.args.type === 'rawSql' ? rethrowAsUserFacingRawError(err) : rethrowAsUserFacing(err),\n ),\n )\n }\n\n return { value: sum }\n }\n\n case 'query': {\n const queries = renderQuery(node.args, context.scope, context.generators, this.#maxChunkSize())\n\n let results: SqlResultSet | undefined\n for (const query of queries) {\n const commentedQuery = applyComments(query, context.sqlCommenter)\n const result = await this.#withQuerySpanAndEvent(commentedQuery, context.queryable, () =>\n context.queryable\n .queryRaw(commentedQuery)\n .catch((err) =>\n node.args.type === 'rawSql' ? rethrowAsUserFacingRawError(err) : rethrowAsUserFacing(err),\n ),\n )\n if (results === undefined) {\n results = result\n } else {\n results.rows.push(...result.rows)\n results.lastInsertId = result.lastInsertId\n }\n }\n\n return {\n value: node.args.type === 'rawSql' ? this.#rawSerializer(results!) : this.#serializer(results!),\n lastInsertId: results?.lastInsertId,\n }\n }\n\n case 'reverse': {\n const { value, lastInsertId } = await this.interpretNode(node.args, context)\n return { value: Array.isArray(value) ? value.reverse() : value, lastInsertId }\n }\n\n case 'unique': {\n const { value, lastInsertId } = await this.interpretNode(node.args, context)\n if (!Array.isArray(value)) {\n return { value, lastInsertId }\n }\n if (value.length > 1) {\n throw new Error(`Expected zero or one element, got ${value.length}`)\n }\n return { value: value[0] ?? null, lastInsertId }\n }\n\n case 'required': {\n const { value, lastInsertId } = await this.interpretNode(node.args, context)\n if (isEmpty(value)) {\n throw new Error('Required value is empty')\n }\n return { value, lastInsertId }\n }\n\n case 'mapField': {\n const { value, lastInsertId } = await this.interpretNode(node.args.records, context)\n return { value: mapField(value, node.args.field), lastInsertId }\n }\n\n case 'join': {\n const { value: parent, lastInsertId } = await this.interpretNode(node.args.parent, context)\n\n if (parent === null) {\n return { value: null, lastInsertId }\n }\n\n const children = (await Promise.all(\n node.args.children.map(async (joinExpr) => ({\n joinExpr,\n childRecords: (await this.interpretNode(joinExpr.child, context)).value,\n })),\n )) satisfies JoinExpressionWithRecords[]\n\n return { value: attachChildrenToParents(parent, children), lastInsertId }\n }\n\n case 'transaction': {\n if (!context.transactionManager.enabled) {\n return this.interpretNode(node.args, context)\n }\n\n const transactionManager = context.transactionManager.manager\n const transactionInfo = await transactionManager.startInternalTransaction()\n const transaction = await transactionManager.getTransaction(transactionInfo, 'query')\n try {\n const value = await this.interpretNode(node.args, { ...context, queryable: transaction })\n await transactionManager.commitTransaction(transactionInfo.id)\n return value\n } catch (e) {\n await transactionManager.rollbackTransaction(transactionInfo.id)\n throw e\n }\n }\n\n case 'dataMap': {\n const { value, lastInsertId } = await this.interpretNode(node.args.expr, context)\n return { value: applyDataMap(value, node.args.structure, node.args.enums), lastInsertId }\n }\n\n case 'validate': {\n const { value, lastInsertId } = await this.interpretNode(node.args.expr, context)\n performValidation(value, node.args.rules, node.args)\n\n return { value, lastInsertId }\n }\n\n case 'if': {\n const { value } = await this.interpretNode(node.args.value, context)\n if (doesSatisfyRule(value, node.args.rule)) {\n return await this.interpretNode(node.args.then, context)\n } else {\n return await this.interpretNode(node.args.else, context)\n }\n }\n\n case 'unit': {\n return { value: undefined }\n }\n\n case 'diff': {\n const { value: from } = await this.interpretNode(node.args.from, context)\n const { value: to } = await this.interpretNode(node.args.to, context)\n\n const keyGetter = (item: Value) => (item !== null ? getRecordKey(asRecord(item), node.args.fields) : null)\n\n const toSet = new Set(asList(to).map(keyGetter))\n return { value: asList(from).filter((item) => !toSet.has(keyGetter(item))) }\n }\n\n case 'process': {\n const { value, lastInsertId } = await this.interpretNode(node.args.expr, context)\n return { value: processRecords(value, node.args.operations), lastInsertId }\n }\n\n case 'initializeRecord': {\n const { lastInsertId } = await this.interpretNode(node.args.expr, context)\n\n const record = {}\n for (const [key, initializer] of Object.entries(node.args.fields)) {\n record[key] = evalFieldInitializer(initializer, lastInsertId, context.scope, context.generators)\n }\n return { value: record, lastInsertId }\n }\n\n case 'mapRecord': {\n const { value, lastInsertId } = await this.interpretNode(node.args.expr, context)\n\n const record = value === null ? {} : asRecord(value)\n for (const [key, entry] of Object.entries(node.args.fields)) {\n record[key] = evalFieldOperation(entry, record[key], context.scope, context.generators)\n }\n return { value: record, lastInsertId }\n }\n\n default:\n assertNever(node, `Unexpected node type: ${(node as { type: unknown }).type}`)\n }\n }\n\n #maxChunkSize(): number | undefined {\n if (this.#connectionInfo?.maxBindValues !== undefined) {\n return this.#connectionInfo.maxBindValues\n }\n return this.#providerMaxChunkSize()\n }\n\n #providerMaxChunkSize(): number | undefined {\n if (this.#provider === undefined) {\n return undefined\n }\n switch (this.#provider) {\n case 'cockroachdb':\n case 'postgres':\n case 'postgresql':\n case 'prisma+postgres':\n return 32766\n case 'mysql':\n return 65535\n case 'sqlite':\n return 999\n case 'sqlserver':\n return 2098\n case 'mongodb':\n return undefined\n default:\n assertNever(this.#provider, `Unexpected provider: ${this.#provider}`)\n }\n }\n\n #withQuerySpanAndEvent<T>(query: SqlQuery, queryable: SqlQueryable, execute: () => Promise<T>): Promise<T> {\n return withQuerySpanAndEvent({\n query,\n execute,\n provider: this.#provider ?? queryable.provider,\n tracingHelper: this.#tracingHelper,\n onQuery: this.#onQuery,\n })\n }\n}\n\ntype IntermediateValue = { value: Value; lastInsertId?: string }\n\nfunction isEmpty(value: Value): boolean {\n if (Array.isArray(value)) {\n return value.length === 0\n }\n return value == null\n}\n\nfunction asList(value: Value): Value[] {\n return Array.isArray(value) ? value : [value]\n}\n\nfunction asNumber(value: Value): number {\n if (typeof value === 'number') {\n return value\n }\n\n if (typeof value === 'string') {\n return Number(value)\n }\n\n throw new Error(`Expected number, got ${typeof value}`)\n}\n\nfunction asRecord(value: Value): PrismaObject {\n if (typeof value === 'object' && value !== null) {\n return value as PrismaObject\n }\n throw new Error(`Expected object, got ${typeof value}`)\n}\n\nfunction mapField(value: Value, field: string): Value {\n if (Array.isArray(value)) {\n return value.map((element) => mapField(element, field))\n }\n\n if (typeof value === 'object' && value !== null) {\n return value[field] ?? null\n }\n\n return value\n}\n\ntype JoinExpressionWithRecords = {\n joinExpr: JoinExpression\n childRecords: Value\n}\n\nfunction attachChildrenToParents(parentRecords: unknown, children: JoinExpressionWithRecords[]) {\n for (const { joinExpr, childRecords } of children) {\n const parentKeys = joinExpr.on.map(([k]) => k)\n const childKeys = joinExpr.on.map(([, k]) => k)\n const parentMap = {}\n\n for (const parent of Array.isArray(parentRecords) ? parentRecords : [parentRecords]) {\n const parentRecord = asRecord(parent)\n const key = getRecordKey(parentRecord, parentKeys)\n if (!parentMap[key]) {\n parentMap[key] = []\n }\n parentMap[key].push(parentRecord)\n\n if (joinExpr.isRelationUnique) {\n parentRecord[joinExpr.parentField] = null\n } else {\n parentRecord[joinExpr.parentField] = []\n }\n }\n\n for (const childRecord of Array.isArray(childRecords) ? childRecords : [childRecords]) {\n if (childRecord === null) {\n continue\n }\n\n const key = getRecordKey(asRecord(childRecord), childKeys)\n for (const parentRecord of parentMap[key] ?? []) {\n if (joinExpr.isRelationUnique) {\n parentRecord[joinExpr.parentField] = childRecord\n } else {\n parentRecord[joinExpr.parentField].push(childRecord)\n }\n }\n }\n }\n\n return parentRecords\n}\n\nfunction evalFieldInitializer(\n initializer: FieldInitializer,\n lastInsertId: string | undefined,\n scope: ScopeBindings,\n generators: GeneratorRegistrySnapshot,\n): Value {\n switch (initializer.type) {\n case 'value':\n return evaluateArg(initializer.value, scope, generators)\n case 'lastInsertId':\n return lastInsertId\n default:\n assertNever(initializer, `Unexpected field initializer type: ${initializer['type']}`)\n }\n}\n\nfunction evalFieldOperation(\n op: FieldOperation,\n value: Value,\n scope: ScopeBindings,\n generators: GeneratorRegistrySnapshot,\n): Value {\n switch (op.type) {\n case 'set':\n return evaluateArg(op.value, scope, generators)\n case 'add':\n return asNumber(value) + asNumber(evaluateArg(op.value, scope, generators))\n case 'subtract':\n return asNumber(value) - asNumber(evaluateArg(op.value, scope, generators))\n case 'multiply':\n return asNumber(value) * asNumber(evaluateArg(op.value, scope, generators))\n case 'divide': {\n const lhs = asNumber(value)\n const rhs = asNumber(evaluateArg(op.value, scope, generators))\n // SQLite and older versions of MySQL return NULL for division by zero, so we emulate\n // that behavior here.\n // If the database does not permit division by zero, a database error should be raised,\n // preventing this case from being executed.\n if (rhs === 0) {\n return null\n }\n return lhs / rhs\n }\n default:\n assertNever(op, `Unexpected field operation type: ${op['type']}`)\n }\n}\n\nfunction applyComments(query: SqlQuery, sqlCommenter?: QueryInterpreterSqlCommenter): SqlQuery {\n if (!sqlCommenter || sqlCommenter.plugins.length === 0) {\n return query\n }\n\n const comment = buildSqlComment(sqlCommenter.plugins, {\n query: sqlCommenter.queryInfo,\n sql: query.sql,\n })\n\n if (!comment) {\n return query\n }\n\n return {\n ...query,\n sql: appendSqlComment(query.sql, comment),\n }\n}\n", "type Crypto = {\n randomUUID: () => string\n}\n\nasync function getCrypto(): Promise<Crypto> {\n // TODO: always use `globalThis.crypto` when we drop Node.js 18 support\n return globalThis.crypto ?? (await import('node:crypto'))\n}\n\nexport async function randomUUID(): Promise<string> {\n const crypto = await getCrypto()\n return crypto.randomUUID()\n}\n", "/**\n * Equivalent to `once` from `node:events` for DOM {@link EventTarget}.\n *\n * It is useful, e.g., to wait for an `abort` event on {@link AbortSignal}.\n * While in Node.js `AbortSignal` does implement `EventEmitter` interface\n * and is compatible with the `once` utility in `node:events`, it is not\n * necessarily the case in other JS runtimes.\n */\nexport async function once(target: EventTarget, event: string): Promise<Event> {\n return new Promise((resolve) => {\n target.addEventListener(event, resolve, { once: true })\n })\n}\n", "import { UserFacingError } from '../user-facing-error'\n\nexport class TransactionManagerError extends UserFacingError {\n name = 'TransactionManagerError'\n\n constructor(message: string, meta?: Record<string, unknown>) {\n super('Transaction API error: ' + message, 'P2028', meta)\n }\n}\n\nexport class TransactionNotFoundError extends TransactionManagerError {\n constructor() {\n super(\n \"Transaction not found. Transaction ID is invalid, refers to an old closed transaction Prisma doesn't have information about anymore, or was obtained before disconnecting.\",\n )\n }\n}\n\nexport class TransactionClosedError extends TransactionManagerError {\n constructor(operation: string) {\n super(`Transaction already closed: A ${operation} cannot be executed on a committed transaction.`)\n }\n}\n\nexport class TransactionRolledBackError extends TransactionManagerError {\n constructor(operation: string) {\n super(`Transaction already closed: A ${operation} cannot be executed on a transaction that was rolled back.`)\n }\n}\n\nexport class TransactionStartTimeoutError extends TransactionManagerError {\n constructor() {\n super('Unable to start a transaction in the given time.')\n }\n}\n\nexport class TransactionExecutionTimeoutError extends TransactionManagerError {\n constructor(operation: string, { timeout, timeTaken }: { timeout: number; timeTaken: number }) {\n super(\n `A ${operation} cannot be executed on an expired transaction. \\\nThe timeout for this transaction was ${timeout} ms, however ${timeTaken} ms passed since the start \\\nof the transaction. Consider increasing the interactive transaction timeout \\\nor doing less work in the transaction.`,\n { operation, timeout, timeTaken },\n )\n }\n}\n\nexport class TransactionInternalConsistencyError extends TransactionManagerError {\n constructor(message: string) {\n super(`Internal Consistency Error: ${message}`)\n }\n}\n\nexport class InvalidTransactionIsolationLevelError extends TransactionManagerError {\n constructor(isolationLevel: string) {\n super(`Invalid isolation level: ${isolationLevel}`, { isolationLevel })\n }\n}\n", "import { Debug } from '@prisma/debug'\nimport { SqlDriverAdapter, SqlQuery, SqlQueryable, Transaction } from '@prisma/driver-adapter-utils'\n\nimport { randomUUID } from '../crypto'\nimport { QueryEvent } from '../events'\nimport type { SchemaProvider } from '../schema'\nimport { TracingHelper, withQuerySpanAndEvent } from '../tracing'\nimport { rethrowAsUserFacing } from '../user-facing-error'\nimport { assertNever } from '../utils'\nimport { once } from '../web-platform'\nimport { Options, TransactionInfo } from './transaction'\nimport {\n InvalidTransactionIsolationLevelError,\n TransactionClosedError,\n TransactionExecutionTimeoutError,\n TransactionInternalConsistencyError,\n TransactionManagerError,\n TransactionNotFoundError,\n TransactionRolledBackError,\n TransactionStartTimeoutError,\n} from './transaction-manager-error'\n\nconst MAX_CLOSED_TRANSACTIONS = 100\n\ntype TransactionWrapper = {\n id: string\n timer?: NodeJS.Timeout\n timeout: number | undefined\n startedAt: number\n transaction?: Transaction\n} & TransactionState\n\ntype TransactionState =\n | { status: 'waiting' | 'running' | 'committed' | 'rolled_back' | 'timed_out' }\n | { status: 'closing'; closing: Promise<void>; reason: 'committed' | 'rolled_back' | 'timed_out' }\n\nconst debug = Debug('prisma:client:transactionManager')\n\nconst COMMIT_QUERY = (): SqlQuery => ({ sql: 'COMMIT', args: [], argTypes: [] })\nconst ROLLBACK_QUERY = (): SqlQuery => ({ sql: 'ROLLBACK', args: [], argTypes: [] })\n\nconst PHANTOM_COMMIT_QUERY = (): SqlQuery => ({\n sql: '-- Implicit \"COMMIT\" query via underlying driver',\n args: [],\n argTypes: [],\n})\nconst PHANTOM_ROLLBACK_QUERY = (): SqlQuery => ({\n sql: '-- Implicit \"ROLLBACK\" query via underlying driver',\n args: [],\n argTypes: [],\n})\n\nexport class TransactionManager {\n // The map of active transactions.\n private transactions: Map<string, TransactionWrapper> = new Map()\n // List of last closed transactions. Max MAX_CLOSED_TRANSACTIONS entries.\n // Used to provide better error messages than a generic \"transaction not found\".\n private closedTransactions: TransactionWrapper[] = []\n private readonly driverAdapter: SqlDriverAdapter\n private readonly transactionOptions: Options\n private readonly tracingHelper: TracingHelper\n readonly #onQuery?: (event: QueryEvent) => void\n readonly #provider?: SchemaProvider\n\n constructor({\n driverAdapter,\n transactionOptions,\n tracingHelper,\n onQuery,\n provider,\n }: {\n driverAdapter: SqlDriverAdapter\n transactionOptions: Options\n tracingHelper: TracingHelper\n onQuery?: (event: QueryEvent) => void\n provider?: SchemaProvider\n }) {\n this.driverAdapter = driverAdapter\n this.transactionOptions = transactionOptions\n this.tracingHelper = tracingHelper\n this.#onQuery = onQuery\n this.#provider = provider\n }\n\n /**\n * Starts an internal transaction. The difference to `startTransaction` is that it does not\n * use the default transaction options from the `TransactionManager`, which in practice means\n * that it does not apply the default timeouts.\n */\n async startInternalTransaction(options?: Options): Promise<TransactionInfo> {\n const validatedOptions = options !== undefined ? this.#validateOptions(options) : {}\n return await this.tracingHelper.runInChildSpan('start_transaction', () =>\n this.#startTransactionImpl(validatedOptions),\n )\n }\n\n async startTransaction(options?: Options): Promise<TransactionInfo> {\n const validatedOptions = options !== undefined ? this.#validateOptions(options) : this.transactionOptions\n return await this.tracingHelper.runInChildSpan('start_transaction', () =>\n this.#startTransactionImpl(validatedOptions),\n )\n }\n\n async #startTransactionImpl(options: Options): Promise<TransactionInfo> {\n const transaction: TransactionWrapper = {\n id: await randomUUID(),\n status: 'waiting',\n timer: undefined,\n timeout: options.timeout,\n startedAt: Date.now(),\n transaction: undefined,\n }\n\n // Start timeout to wait for transaction to be started.\n const abortController = new AbortController()\n const startTimer = createTimeoutIfDefined(() => abortController.abort(), options.maxWait)\n startTimer?.unref?.()\n\n // Keep a reference to the startTransaction promise so we can clean up\n // if the timeout fires before it completes.\n const startTransactionPromise = this.driverAdapter\n .startTransaction(options.isolationLevel)\n .catch(rethrowAsUserFacing)\n\n transaction.transaction = await Promise.race([\n startTransactionPromise.finally(() => clearTimeout(startTimer)),\n once(abortController.signal, 'abort').then(() => undefined),\n ])\n\n this.transactions.set(transaction.id, transaction)\n\n // Transaction status might have timed out while waiting for transaction to start. => Check for it!\n switch (transaction.status) {\n case 'waiting':\n if (abortController.signal.aborted) {\n // The startTransaction promise may still be running in the background.\n // If it eventually succeeds, we need to release the connection to avoid\n // leaking it and exhausting the connection pool. We ignore any errors\n // that happen during startup or rollback here because we will have\n // already returned our own `TransactionStartTimeoutError` error to the user.\n void startTransactionPromise\n .then((tx) => tx.rollback())\n .catch((e) => debug('error in discarded transaction:', e))\n\n // Call `#closeTransaction` to update internal state. It won't actually attempt\n // to rollback the tx itself because `transaction.transaction` is undefined.\n await this.#closeTransaction(transaction, 'timed_out')\n\n throw new TransactionStartTimeoutError()\n }\n\n transaction.status = 'running'\n // Start timeout to wait for transaction to be finished.\n transaction.timer = this.#startTransactionTimeout(transaction.id, options.timeout)\n return { id: transaction.id }\n case 'timed_out':\n case 'running':\n case 'committed':\n case 'rolled_back':\n throw new TransactionInternalConsistencyError(\n `Transaction in invalid state ${transaction.status} although it just finished startup.`,\n )\n default:\n assertNever(transaction['status'], 'Unknown transaction status.')\n }\n }\n\n async commitTransaction(transactionId: string): Promise<void> {\n return await this.tracingHelper.runInChildSpan('commit_transaction', async () => {\n const txw = this.#getActiveOrClosingTransaction(transactionId, 'commit')\n await this.#closeTransaction(txw, 'committed')\n })\n }\n\n async rollbackTransaction(transactionId: string): Promise<void> {\n return await this.tracingHelper.runInChildSpan('rollback_transaction', async () => {\n const txw = this.#getActiveOrClosingTransaction(transactionId, 'rollback')\n await this.#closeTransaction(txw, 'rolled_back')\n })\n }\n\n async getTransaction(txInfo: TransactionInfo, operation: string): Promise<Transaction> {\n let tx = this.#getActiveOrClosingTransaction(txInfo.id, operation)\n if (tx.status === 'closing') {\n await tx.closing\n // Fetch again to ensure proper error propagation after it's been closed.\n tx = this.#getActiveOrClosingTransaction(txInfo.id, operation)\n }\n if (!tx.transaction) throw new TransactionNotFoundError()\n return tx.transaction\n }\n\n #getActiveOrClosingTransaction(transactionId: string, operation: string): TransactionWrapper {\n const transaction = this.transactions.get(transactionId)\n\n if (!transaction) {\n const closedTransaction = this.closedTransactions.find((tx) => tx.id === transactionId)\n if (closedTransaction) {\n debug('Transaction already closed.', { transactionId, status: closedTransaction.status })\n switch (closedTransaction.status) {\n case 'closing':\n case 'waiting':\n case 'running':\n throw new TransactionInternalConsistencyError('Active transaction found in closed transactions list.')\n case 'committed':\n throw new TransactionClosedError(operation)\n case 'rolled_back':\n throw new TransactionRolledBackError(operation)\n case 'timed_out':\n throw new TransactionExecutionTimeoutError(operation, {\n timeout: closedTransaction.timeout!,\n timeTaken: Date.now() - closedTransaction.startedAt,\n })\n }\n } else {\n debug(`Transaction not found.`, transactionId)\n throw new TransactionNotFoundError()\n }\n }\n\n if (['committed', 'rolled_back', 'timed_out'].includes(transaction.status)) {\n throw new TransactionInternalConsistencyError('Closed transaction found in active transactions map.')\n }\n\n return transaction\n }\n\n async cancelAllTransactions(): Promise<void> {\n // TODO: call `map` on the iterator directly without collecting it into an array first\n // once we drop support for Node.js 18 and 20.\n await Promise.allSettled([...this.transactions.values()].map((tx) => this.#closeTransaction(tx, 'rolled_back')))\n }\n\n #startTransactionTimeout(transactionId: string, timeout: number | undefined): NodeJS.Timeout | undefined {\n const timeoutStartedAt = Date.now()\n const timer = createTimeoutIfDefined(async () => {\n debug('Transaction timed out.', { transactionId, timeoutStartedAt, timeout })\n\n const tx = this.transactions.get(transactionId)\n if (tx && ['running', 'waiting'].includes(tx.status)) {\n await this.#closeTransaction(tx, 'timed_out')\n } else {\n // Transaction was already committed or rolled back when timeout happened.\n // Should normally not happen as timeout is cancelled when transaction is committed or rolled back.\n // No further action needed though.\n debug('Transaction already committed or rolled back when timeout happened.', transactionId)\n }\n }, timeout)\n\n timer?.unref?.()\n return timer\n }\n\n async #closeTransaction(tx: TransactionWrapper, status: 'committed' | 'rolled_back' | 'timed_out'): Promise<void> {\n const createClosingPromise = async () => {\n debug('Closing transaction.', { transactionId: tx.id, status })\n try {\n if (tx.transaction && status === 'committed') {\n if (tx.transaction.options.usePhantomQuery) {\n await this.#withQuerySpanAndEvent(PHANTOM_COMMIT_QUERY(), tx.transaction, () => tx.transaction!.commit())\n } else {\n const query = COMMIT_QUERY()\n await this.#withQuerySpanAndEvent(query, tx.transaction, () => tx.transaction!.executeRaw(query)).then(\n () => tx.transaction!.commit(),\n (err) => {\n const fail = () => Promise.reject(err)\n return tx.transaction!.rollback().then(fail, fail)\n },\n )\n }\n } else if (tx.transaction) {\n if (tx.transaction.options.usePhantomQuery) {\n await this.#withQuerySpanAndEvent(PHANTOM_ROLLBACK_QUERY(), tx.transaction, () =>\n tx.transaction!.rollback(),\n )\n } else {\n const query = ROLLBACK_QUERY()\n try {\n await this.#withQuerySpanAndEvent(query, tx.transaction, () => tx.transaction!.executeRaw(query))\n } finally {\n await tx.transaction.rollback()\n }\n }\n }\n } finally {\n tx.status = status\n clearTimeout(tx.timer)\n tx.timer = undefined\n\n this.transactions.delete(tx.id)\n\n this.closedTransactions.push(tx)\n if (this.closedTransactions.length > MAX_CLOSED_TRANSACTIONS) {\n this.closedTransactions.shift()\n }\n }\n }\n\n if (tx.status === 'closing') {\n await tx.closing\n // Fetch again to ensure proper error propagation after it's been closed.\n this.#getActiveOrClosingTransaction(tx.id, status === 'committed' ? 'commit' : 'rollback')\n } else {\n await Object.assign(tx, {\n status: 'closing',\n reason: status,\n closing: createClosingPromise(),\n }).closing\n }\n }\n\n #validateOptions(options: Options) {\n // Supplying timeout default values is cared for upstream already.\n if (!options.timeout) throw new TransactionManagerError('timeout is required')\n if (!options.maxWait) throw new TransactionManagerError('maxWait is required')\n\n // Snapshot level only supported for MS SQL Server, which is not supported via driver adapters so far.\n if (options.isolationLevel === 'SNAPSHOT') throw new InvalidTransactionIsolationLevelError(options.isolationLevel)\n\n return {\n ...options,\n timeout: options.timeout,\n maxWait: options.maxWait,\n }\n }\n\n #withQuerySpanAndEvent<T>(query: SqlQuery, queryable: SqlQueryable, execute: () => Promise<T>): Promise<T> {\n return withQuerySpanAndEvent({\n query,\n execute,\n provider: this.#provider ?? queryable.provider,\n tracingHelper: this.tracingHelper,\n onQuery: this.#onQuery,\n })\n }\n}\n\nfunction createTimeoutIfDefined(cb: () => void, ms: number | undefined): NodeJS.Timeout | undefined {\n return ms !== undefined ? setTimeout(cb, ms) : undefined\n}\n", "import { QueryCompiler, QueryCompilerConstructor, QueryEngineLogLevel } from '@prisma/client-common'\nimport {\n BatchResponse,\n convertCompactedRows,\n QueryEvent,\n QueryPlanNode,\n safeJsonStringify,\n TransactionInfo,\n UserFacingError,\n} from '@prisma/client-engine-runtime'\nimport {\n PrismaClientInitializationError,\n PrismaClientKnownRequestError,\n PrismaClientRustPanicError,\n PrismaClientUnknownRequestError,\n} from '@prisma/client-runtime-utils'\nimport { Debug } from '@prisma/debug'\nimport type { IsolationLevel as SqlIsolationLevel, SqlDriverAdapterFactory } from '@prisma/driver-adapter-utils'\nimport type { ActiveConnectorType } from '@prisma/generator'\nimport type { TracingHelper } from '@prisma/instrumentation-contract'\nimport { assertNever } from '@prisma/internals'\nimport type { JsonBatchQuery, JsonQuery, RawJsonQuery } from '@prisma/json-protocol'\nimport { ParamGraph } from '@prisma/param-graph'\n\nimport { version as clientVersion } from '../../../../../package.json'\nimport { deserializeRawParameters } from '../../../utils/deserializeRawParameters'\nimport type { BatchQueryEngineResult, EngineConfig, RequestBatchOptions, RequestOptions } from '../common/Engine'\nimport { Engine } from '../common/Engine'\nimport { LogEmitter, QueryEvent as ClientQueryEvent } from '../common/types/Events'\nimport { RustRequestError, SyncRustError } from '../common/types/QueryEngine'\nimport type * as Tx from '../common/types/Transaction'\nimport { InteractiveTransactionInfo } from '../common/types/Transaction'\nimport { getBatchRequestPayload } from '../common/utils/getBatchRequestPayload'\nimport { getErrorMessageWithLink as genericGetErrorMessageWithLink } from '../common/utils/getErrorMessageWithLink'\nimport type { Executor } from './Executor'\nimport { LocalExecutor } from './LocalExecutor'\nimport { parameterizeBatch, parameterizeQuery } from './parameterization/parameterize'\nimport { QueryPlanCache } from './QueryPlanCache'\nimport { RemoteExecutor } from './RemoteExecutor'\nimport { QueryCompilerLoader } from './types/QueryCompiler'\nimport { wasmQueryCompilerLoader } from './WasmQueryCompilerLoader'\n\nconst CLIENT_ENGINE_ERROR = 'P2038'\n\nconst debug = Debug('prisma:client:clientEngine')\n\ntype GlobalWithPanicHandler = typeof globalThis & {\n PRISMA_WASM_PANIC_REGISTRY: {\n set_message?: (message: string) => void\n }\n}\n\nconst globalWithPanicHandler = globalThis as GlobalWithPanicHandler\n\n// The fallback panic handler shared across all instances. This ensures that any\n// panic is caught and handled, but each instance should prefer temporarily\n// setting its own local panic handler for the duration of a synchronous WASM\n// function call for better error messages.\nglobalWithPanicHandler.PRISMA_WASM_PANIC_REGISTRY = {\n set_message(message: string) {\n throw new PrismaClientRustPanicError(message, clientVersion)\n },\n}\n\ninterface ConnectedEngine {\n executor: Executor\n queryCompiler: QueryCompiler\n}\n\ntype EngineState =\n | {\n type: 'disconnected'\n }\n | {\n type: 'connecting'\n promise: Promise<ConnectedEngine>\n }\n | {\n type: 'connected'\n engine: ConnectedEngine\n }\n | {\n type: 'disconnecting'\n promise: Promise<void>\n }\n\ntype ExecutorKind =\n | {\n remote: false\n driverAdapterFactory: SqlDriverAdapterFactory\n }\n | {\n remote: true\n accelerateUrl: string\n }\n\nexport class ClientEngine implements Engine {\n name = 'ClientEngine' as const\n\n #QueryCompilerConstructor?: QueryCompilerConstructor\n #state: EngineState = { type: 'disconnected' }\n #queryCompilerLoader: QueryCompilerLoader\n #executorKind: ExecutorKind\n #queryPlanCache: QueryPlanCache\n // todo: remove this\n #queryPlanCacheEnabled: boolean\n #paramGraph: ParamGraph\n\n config: EngineConfig\n datamodel: string\n\n logEmitter: LogEmitter\n logQueries: boolean\n logLevel: QueryEngineLogLevel\n tracingHelper: TracingHelper\n\n #emitQueryEvent?: (event: QueryEvent) => void\n\n constructor(config: EngineConfig, queryCompilerLoader?: QueryCompilerLoader) {\n if (config.accelerateUrl !== undefined) {\n this.#executorKind = { remote: true, accelerateUrl: config.accelerateUrl }\n } else if (config.adapter) {\n this.#executorKind = { remote: false, driverAdapterFactory: config.adapter }\n debug('Using driver adapter: %O', config.adapter)\n } else {\n throw new PrismaClientInitializationError(\n 'Missing configured driver adapter. Engine type `client` requires an active driver adapter. Please check your PrismaClient initialization code.',\n config.clientVersion,\n CLIENT_ENGINE_ERROR,\n )\n }\n\n if (TARGET_BUILD_TYPE === 'client' || TARGET_BUILD_TYPE === 'wasm-compiler-edge') {\n this.#queryCompilerLoader = queryCompilerLoader ?? wasmQueryCompilerLoader\n } else {\n throw new Error(`Invalid TARGET_BUILD_TYPE: ${TARGET_BUILD_TYPE}`)\n }\n\n this.config = config\n this.logQueries = config.logQueries ?? false\n this.logLevel = config.logLevel ?? 'error'\n this.logEmitter = config.logEmitter\n this.datamodel = config.inlineSchema\n this.tracingHelper = config.tracingHelper\n this.#queryPlanCache = new QueryPlanCache()\n this.#queryPlanCacheEnabled = true\n this.#paramGraph = ParamGraph.deserialize(config.parameterizationSchema, (enumName) => {\n if (!Object.hasOwn(config.runtimeDataModel.enums, enumName)) {\n return undefined\n }\n return config.runtimeDataModel.enums[enumName].values.map((v) => v.name)\n })\n\n if (config.enableDebugLogs) {\n this.logLevel = 'debug'\n }\n\n if (this.logQueries) {\n this.#emitQueryEvent = (event: QueryEvent) => {\n this.logEmitter.emit('query', {\n ...event,\n // TODO: we should probably change the interface to contain a proper array in the next major version.\n params: safeJsonStringify(event.params),\n // TODO: this field only exists for historical reasons as we grandfathered it from the time\n // when we emitted `tracing` events to stdout in the engine unchanged, and then described\n // them in the public API as TS types. Thus this field used to contain the name of the Rust\n // module in which an event originated. When using library engine, which uses a different\n // mechanism with a JavaScript callback for logs, it's normally just an empty string instead.\n // This field is definitely not useful and should be removed from the public types (but it's\n // technically a breaking change, even if a tiny and inconsequential one).\n target: 'ClientEngine',\n } satisfies ClientQueryEvent)\n }\n }\n }\n\n async #ensureStarted(): Promise<ConnectedEngine> {\n switch (this.#state.type) {\n case 'disconnected': {\n const connecting = this.tracingHelper.runInChildSpan('connect', async () => {\n let executor: Executor | undefined = undefined\n let queryCompiler: QueryCompiler | undefined = undefined\n\n try {\n executor = await this.#connectExecutor()\n queryCompiler = await this.#instantiateQueryCompiler(executor)\n } catch (error) {\n this.#state = { type: 'disconnected' }\n queryCompiler?.free()\n await executor?.disconnect()\n throw error\n }\n\n const engine: ConnectedEngine = {\n executor,\n queryCompiler,\n }\n\n this.#state = { type: 'connected', engine }\n\n return engine\n })\n\n this.#state = {\n type: 'connecting',\n promise: connecting,\n }\n\n return await connecting\n }\n\n case 'connecting':\n return await this.#state.promise\n\n case 'connected':\n return this.#state.engine\n\n case 'disconnecting':\n await this.#state.promise\n return await this.#ensureStarted()\n }\n }\n\n async #connectExecutor(): Promise<Executor> {\n if (this.#executorKind.remote) {\n return new RemoteExecutor({\n clientVersion: this.config.clientVersion,\n accelerateUrl: this.#executorKind.accelerateUrl,\n logEmitter: this.logEmitter,\n logLevel: this.logLevel,\n logQueries: this.logQueries,\n tracingHelper: this.tracingHelper,\n sqlCommenters: this.config.sqlCommenters,\n })\n } else {\n return await LocalExecutor.connect({\n driverAdapterFactory: this.#executorKind.driverAdapterFactory,\n tracingHelper: this.tracingHelper,\n transactionOptions: {\n ...this.config.transactionOptions,\n isolationLevel: this.#convertIsolationLevel(this.config.transactionOptions.isolationLevel),\n },\n onQuery: this.#emitQueryEvent,\n provider: this.config.activeProvider as ActiveConnectorType | undefined,\n sqlCommenters: this.config.sqlCommenters,\n })\n }\n }\n\n async #instantiateQueryCompiler(executor: Executor): Promise<QueryCompiler> {\n // We reuse the `QueryCompilerConstructor` from the same `WebAssembly.Instance` between\n // reconnects as long as there are no panics. This avoids the overhead of loading and\n // JIT compiling the WebAssembly module after every reconnect. If it panics, we discard\n // it and load a new one from scratch if the client reconnects again.\n let QueryCompilerConstructor = this.#QueryCompilerConstructor\n\n if (QueryCompilerConstructor === undefined) {\n QueryCompilerConstructor = await this.#queryCompilerLoader.loadQueryCompiler(this.config)\n this.#QueryCompilerConstructor = QueryCompilerConstructor\n }\n\n const { provider, connectionInfo } = await executor.getConnectionInfo()\n\n try {\n return this.#withLocalPanicHandler(\n () =>\n new QueryCompilerConstructor({\n datamodel: this.datamodel,\n provider,\n connectionInfo,\n }),\n undefined,\n false,\n )\n } catch (e) {\n throw this.#transformInitError(e)\n }\n }\n\n #transformInitError(err: Error): Error {\n if (err instanceof PrismaClientRustPanicError) {\n return err\n }\n try {\n const error: SyncRustError = JSON.parse(err.message)\n return new PrismaClientInitializationError(error.message, this.config.clientVersion, error.error_code)\n } catch (e) {\n return err\n }\n }\n\n #transformRequestError(err: any, query?: string): Error {\n if (err instanceof PrismaClientInitializationError) return err\n\n if (err.code === 'GenericFailure' && err.message?.startsWith('PANIC:'))\n return new PrismaClientRustPanicError(\n getErrorMessageWithLink(this, err.message, query),\n this.config.clientVersion,\n )\n\n if (err instanceof UserFacingError) {\n return new PrismaClientKnownRequestError(err.message, {\n code: err.code,\n meta: err.meta,\n clientVersion: this.config.clientVersion,\n })\n }\n\n try {\n const error: RustRequestError = JSON.parse(err as string)\n return new PrismaClientUnknownRequestError(`${error.message}\\n${error.backtrace}`, {\n clientVersion: this.config.clientVersion,\n })\n } catch (e) {\n return err\n }\n }\n\n #transformCompileError(error: any): any {\n if (error instanceof PrismaClientRustPanicError) {\n return error\n }\n\n if (typeof error['message'] === 'string' && typeof error['code'] === 'string') {\n return new PrismaClientKnownRequestError(error['message'], {\n code: error['code'],\n meta: error.meta,\n clientVersion: this.config.clientVersion,\n })\n } else if (typeof error['message'] === 'string') {\n return new PrismaClientUnknownRequestError(error['message'], { clientVersion: this.config.clientVersion })\n } else {\n return error\n }\n }\n\n #withLocalPanicHandler<T>(fn: () => T, query?: string, disconnectOnPanic = true): T {\n const previousHandler = globalWithPanicHandler.PRISMA_WASM_PANIC_REGISTRY.set_message\n let panic: string | undefined = undefined\n\n global.PRISMA_WASM_PANIC_REGISTRY.set_message = (message: string) => {\n panic = message\n }\n\n try {\n return fn()\n } finally {\n global.PRISMA_WASM_PANIC_REGISTRY.set_message = previousHandler\n\n if (panic) {\n // Discard the current `WebAssembly.Instance` to avoid memory leaks:\n // WebAssembly doesn't unwind the stack or call destructors on panic.\n this.#QueryCompilerConstructor = undefined\n // Disconnect and drop the compiler, unless this panic happened during\n // initialization. In that case, we let `#ensureStarted` deal with it\n // and change the state to `disconnected` by itself.\n if (disconnectOnPanic) {\n void this.stop().catch((err) => debug('failed to disconnect:', err))\n }\n // eslint-disable-next-line no-unsafe-finally\n throw new PrismaClientRustPanicError(getErrorMessageWithLink(this, panic, query), this.config.clientVersion)\n }\n }\n }\n\n onBeforeExit() {\n throw new Error(\n '\"beforeExit\" hook is not applicable to the client engine, it is only relevant and implemented for the binary engine. Please add your event listener to the `process` object directly instead.',\n )\n }\n\n async start(): Promise<void> {\n await this.#ensureStarted()\n }\n\n async stop(): Promise<void> {\n switch (this.#state.type) {\n case 'disconnected':\n return\n\n case 'connecting':\n await this.#state.promise\n return await this.stop()\n\n case 'connected': {\n const engine = this.#state.engine\n\n const disconnecting = this.tracingHelper.runInChildSpan('disconnect', async () => {\n try {\n await engine.executor.disconnect()\n engine.queryCompiler.free()\n } finally {\n this.#state = { type: 'disconnected' }\n }\n })\n\n this.#state = {\n type: 'disconnecting',\n promise: disconnecting,\n }\n\n return await disconnecting\n }\n\n case 'disconnecting':\n return await this.#state.promise\n }\n }\n\n version(): string {\n return 'unknown'\n }\n\n async transaction(\n action: 'start',\n headers: Tx.TransactionHeaders,\n options: Tx.Options,\n ): Promise<Tx.InteractiveTransactionInfo>\n async transaction(\n action: 'commit',\n headers: Tx.TransactionHeaders,\n info: Tx.InteractiveTransactionInfo,\n ): Promise<undefined>\n async transaction(\n action: 'rollback',\n headers: Tx.TransactionHeaders,\n info: Tx.InteractiveTransactionInfo,\n ): Promise<undefined>\n async transaction(\n action: 'start' | 'commit' | 'rollback',\n _headers: Tx.TransactionHeaders,\n arg?: any,\n ): Promise<Tx.InteractiveTransactionInfo | undefined> {\n let result: TransactionInfo | undefined\n\n const { executor } = await this.#ensureStarted()\n\n try {\n if (action === 'start') {\n const options: Tx.Options = arg\n result = await executor.startTransaction({\n ...options,\n isolationLevel: this.#convertIsolationLevel(options.isolationLevel),\n })\n } else if (action === 'commit') {\n const txInfo: Tx.InteractiveTransactionInfo<undefined> = arg\n await executor.commitTransaction(txInfo)\n } else if (action === 'rollback') {\n const txInfo: Tx.InteractiveTransactionInfo<undefined> = arg\n await executor.rollbackTransaction(txInfo)\n } else {\n assertNever(action, 'Invalid transaction action.')\n }\n } catch (error) {\n throw this.#transformRequestError(error)\n }\n\n return result ? { id: result.id, payload: undefined } : undefined\n }\n\n async request<T>(\n query: JsonQuery,\n { interactiveTransaction, customDataProxyFetch }: RequestOptions<unknown>,\n ): Promise<{ data: T }> {\n debug(`sending request`)\n\n const { executor, queryCompiler } = await this.#ensureStarted().catch((err) => {\n throw this.#transformRequestError(err, JSON.stringify(query))\n })\n\n let plan: QueryPlanNode\n let placeholderValues: Record<string, unknown> = {}\n\n if (isRawQuery(query)) {\n plan = compileRawQuery(query)\n } else if (this.#queryPlanCacheEnabled) {\n const { parameterizedQuery, placeholderValues: extractedValues } = parameterizeQuery(query, this.#paramGraph)\n const cacheKey = JSON.stringify(parameterizedQuery)\n placeholderValues = extractedValues\n\n const cached = this.#queryPlanCache.getSingle(cacheKey)\n if (cached) {\n debug('query plan cache hit')\n plan = cached\n } else {\n debug('query plan cache miss')\n plan = this.#compileQuery(parameterizedQuery, cacheKey, queryCompiler)\n this.#queryPlanCache.setSingle(cacheKey, plan)\n }\n } else {\n plan = this.#compileQuery(query, JSON.stringify(query), queryCompiler)\n }\n\n try {\n debug(`query plan created`, plan)\n\n const result = await executor.execute({\n plan,\n model: query.modelName,\n operation: query.action,\n placeholderValues,\n transaction: interactiveTransaction,\n batchIndex: undefined,\n customFetch: customDataProxyFetch?.(globalThis.fetch),\n queryInfo: {\n type: 'single',\n modelName: query.modelName,\n action: query.action,\n query: query.query,\n },\n })\n\n debug(`query plan executed`)\n\n return { data: { [query.action]: result } as T }\n } catch (e: any) {\n throw this.#transformRequestError(e, JSON.stringify(query))\n }\n }\n\n async requestBatch<T>(\n queries: JsonQuery[],\n { transaction, customDataProxyFetch }: RequestBatchOptions<unknown>,\n ): Promise<BatchQueryEngineResult<T>[]> {\n if (queries.length === 0) {\n return []\n }\n\n const firstAction = queries[0].action\n const firstModelName = queries[0].modelName\n\n const batchPayload = getBatchRequestPayload(queries, transaction)\n const request = JSON.stringify(batchPayload)\n\n const { executor, queryCompiler } = await this.#ensureStarted().catch((err) => {\n throw this.#transformRequestError(err, request)\n })\n\n const hasRawQueries = firstModelName === undefined\n let batchResponse: BatchResponse\n let placeholderValues: Record<string, unknown> = {}\n\n if (this.#queryPlanCacheEnabled && !hasRawQueries) {\n const { parameterizedBatch, placeholderValues: extractedValues } = parameterizeBatch(\n batchPayload as JsonBatchQuery,\n this.#paramGraph,\n )\n const cacheKeyStr = JSON.stringify(parameterizedBatch)\n placeholderValues = extractedValues\n\n const cached = this.#queryPlanCache.getBatch(cacheKeyStr)\n if (cached) {\n debug('batch query plan cache hit')\n batchResponse = cached\n } else {\n debug('batch query plan cache miss')\n try {\n batchResponse = this.#compileBatch(parameterizedBatch.batch, cacheKeyStr, queryCompiler)\n this.#queryPlanCache.setBatch(cacheKeyStr, batchResponse)\n } catch (error) {\n throw this.#transformCompileError(error)\n }\n }\n } else {\n batchResponse = this.#compileBatch(queries, request, queryCompiler)\n }\n\n try {\n let txInfo: InteractiveTransactionInfo | undefined\n if (transaction?.kind === 'itx') {\n // If we are already in an interactive transaction we do not nest transactions\n txInfo = transaction.options\n }\n\n switch (batchResponse.type) {\n case 'multi': {\n if (transaction?.kind !== 'itx') {\n const txOptions = transaction?.options.isolationLevel\n ? { ...this.config.transactionOptions, isolationLevel: transaction.options.isolationLevel }\n : this.config.transactionOptions\n txInfo = await this.transaction('start', {}, txOptions)\n }\n\n const results: BatchQueryEngineResult<unknown>[] = []\n let rollback = false\n for (const [batchIndex, plan] of batchResponse.plans.entries()) {\n try {\n const rows = await executor.execute({\n plan: plan as QueryPlanNode,\n placeholderValues,\n model: queries[batchIndex].modelName,\n operation: queries[batchIndex].action,\n batchIndex,\n transaction: txInfo,\n customFetch: customDataProxyFetch?.(globalThis.fetch) as typeof globalThis.fetch | undefined,\n queryInfo: {\n type: 'single',\n ...queries[batchIndex],\n },\n })\n results.push({ data: { [queries[batchIndex].action]: rows } })\n } catch (err) {\n results.push(err as Error)\n rollback = true\n break\n }\n }\n\n if (txInfo !== undefined && transaction?.kind !== 'itx') {\n if (rollback) {\n await this.transaction('rollback', {}, txInfo)\n } else {\n await this.transaction('commit', {}, txInfo)\n }\n }\n return results as BatchQueryEngineResult<T>[]\n }\n case 'compacted': {\n if (!queries.every((q) => q.action === firstAction && q.modelName === firstModelName)) {\n const actions = queries.map((q) => q.action).join(', ')\n const modelNames = queries.map((q) => q.modelName).join(', ')\n throw new Error(\n `Internal error: All queries in a compacted batch must have the same action and model name, but received actions: [${actions}] and model names: [${modelNames}]. ` +\n 'This indicates a bug in the client. Please report this issue to the Prisma team with your query details.',\n )\n }\n\n if (firstModelName === undefined) {\n throw new Error(\n 'Internal error: A compacted batch cannot contain raw queries. ' +\n 'This indicates a bug in the client. Please report this issue to the Prisma team with your query details.',\n )\n }\n\n const rows = await executor.execute({\n plan: batchResponse.plan as QueryPlanNode,\n placeholderValues,\n model: firstModelName,\n operation: firstAction,\n batchIndex: undefined,\n transaction: txInfo,\n customFetch: customDataProxyFetch?.(globalThis.fetch) as typeof globalThis.fetch | undefined,\n queryInfo: {\n type: 'compacted',\n action: firstAction,\n modelName: firstModelName,\n queries,\n },\n })\n\n const results = convertCompactedRows(rows as {}[], batchResponse, placeholderValues)\n return results.map((result) => ({ data: { [firstAction]: result } }) as BatchQueryEngineResult<T>)\n }\n }\n } catch (e: any) {\n throw this.#transformRequestError(e, request)\n }\n }\n\n /**\n * Used by `@prisma/extension-accelerate`\n */\n async apiKey(): Promise<string | null> {\n const { executor } = await this.#ensureStarted()\n return executor.apiKey()\n }\n\n #compileQuery(query: JsonQuery, request: string, compiler: QueryCompiler): QueryPlanNode {\n try {\n return this.#withLocalPanicHandler(() =>\n this.#withCompileSpan({\n queries: [query],\n execute: () => compiler.compile(request) as QueryPlanNode,\n }),\n )\n } catch (error) {\n throw this.#transformCompileError(error)\n }\n }\n\n #compileBatch(queries: JsonQuery[], request: string, compiler: QueryCompiler): BatchResponse {\n if (queries.every(isRawQuery)) {\n return {\n type: 'multi',\n plans: queries.map((q) => compileRawQuery(q)),\n }\n }\n\n try {\n return this.#withLocalPanicHandler(() =>\n this.#withCompileSpan({\n queries,\n execute: () => compiler.compileBatch(request),\n }),\n )\n } catch (err) {\n throw this.#transformCompileError(err)\n }\n }\n\n #convertIsolationLevel(clientIsolationLevel: Tx.IsolationLevel | undefined): SqlIsolationLevel | undefined {\n switch (clientIsolationLevel) {\n case undefined:\n return undefined\n case 'ReadUncommitted':\n return 'READ UNCOMMITTED'\n case 'ReadCommitted':\n return 'READ COMMITTED'\n case 'RepeatableRead':\n return 'REPEATABLE READ'\n case 'Serializable':\n return 'SERIALIZABLE'\n case 'Snapshot':\n return 'SNAPSHOT'\n default:\n throw new PrismaClientKnownRequestError(\n `Inconsistent column data: Conversion failed: Invalid isolation level \\`${\n clientIsolationLevel satisfies never\n }\\``,\n {\n code: 'P2023',\n clientVersion: this.config.clientVersion,\n meta: {\n providedIsolationLevel: clientIsolationLevel,\n },\n },\n )\n }\n }\n\n #withCompileSpan<T>({ queries, execute }: { queries: JsonQuery[]; execute: () => T }): T {\n return this.tracingHelper.runInChildSpan(\n {\n name: 'compile',\n attributes: {\n models: queries.map((q) => q.modelName).filter((m) => m !== undefined),\n actions: queries.map((q) => q.action),\n },\n },\n execute,\n )\n }\n}\n\nfunction getErrorMessageWithLink(engine: ClientEngine, title: string, query?: string) {\n return genericGetErrorMessageWithLink({\n binaryTarget: undefined,\n title,\n version: engine.config.clientVersion,\n engineVersion: 'unknown', // WASM engines do not export their version info\n database: engine.config.activeProvider as any,\n query,\n })\n}\n\nfunction isRawQuery(query: JsonQuery): query is RawJsonQuery {\n return query.action === 'queryRaw' || query.action === 'executeRaw'\n}\n\nfunction compileRawQuery(query: RawJsonQuery): QueryPlanNode {\n const sql = query.query.arguments.query\n const { args, argTypes } = deserializeRawParameters(query.query.arguments.parameters)\n return {\n type: query.action === 'queryRaw' ? 'query' : 'execute',\n args: { type: 'rawSql', sql, args, argTypes },\n }\n}\n", "/**\n * Binary serialization for ParamGraph.\n *\n * This module handles compact binary encoding/decoding of the param graph structure.\n * The format uses a hybrid approach: JSON string array for field names + binary blob\n * for structural data (nodes, edges, roots).\n *\n * ## Serialized Representation\n *\n * ```\n * SerializedParamGraph {\n * strings: string[] // String table (field names, enum names, root keys)\n * graph: string // Base64url-encoded binary blob\n * }\n * ```\n *\n * ## Why Hybrid?\n *\n * - **Strings stay as JSON**: V8's JSON.parse is highly optimized for string arrays\n * - **Structure goes binary**: Indices, flags, masks benefit from compact encoding\n * - **Best of both**: Fast parsing + compact size where it matters\n *\n * ## Variable-Length Encoding\n *\n * All integer values (except fixed-size fields like `scalarMask` and `flags`) use\n * unsigned LEB128 (Little Endian Base 128) variable-length encoding:\n *\n * - Values 0-127: 1 byte\n * - Values 128-16383: 2 bytes\n * - Values 16384-2097151: 3 bytes\n * - And so on...\n *\n * Optional values use value+1 encoding: 0 means \"none/undefined\", N+1 means actual value N.\n *\n * ## Binary Blob Layout\n *\n * ```\n * \u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n * \u2502 HEADER \u2502\n * \u251C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\n * \u2502 inputNodeCount: varuint \u2502\n * \u2502 outputNodeCount: varuint \u2502\n * \u2502 rootCount: varuint \u2502\n * \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n *\n * \u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n * \u2502 INPUT NODES (repeated inputNodeCount times) \u2502\n * \u251C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\n * \u2502 edgeCount: varuint \u2502\n * \u2502 edges[] \u2502\n * \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n *\n * \u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n * \u2502 INPUT EDGE \u2502\n * \u251C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\n * \u2502 fieldIndex: varuint \u2502\n * \u2502 scalarMask: u16 \u2502\n * \u2502 childNodeId: varuint (0=none, N+1=actual) \u2502\n * \u2502 enumNameIndex: varuint (0=none, N+1=actual) \u2502\n * \u2502 flags: u8 \u2502\n * \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n *\n * \u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n * \u2502 OUTPUT NODES (repeated outputNodeCount times) \u2502\n * \u251C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\n * \u2502 edgeCount: varuint \u2502\n * \u2502 edges[] \u2502\n * \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n *\n * \u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n * \u2502 OUTPUT EDGE \u2502\n * \u251C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\n * \u2502 fieldIndex: varuint \u2502\n * \u2502 argsNodeId: varuint (0=none, N+1=actual) \u2502\n * \u2502 outputNodeId: varuint (0=none, N+1=actual) \u2502\n * \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n *\n * \u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n * \u2502 ROOTS (repeated rootCount times) \u2502\n * \u251C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\n * \u2502 keyIndex: varuint \u2502\n * \u2502 argsNodeId: varuint (0=none, N+1=actual) \u2502\n * \u2502 outputNodeId: varuint (0=none, N+1=actual) \u2502\n * \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n * ```\n *\n * ## Embedding in Generated Client\n *\n * ```js\n * config.parameterizationSchema = {\n * strings: JSON.parse('[\"where\",\"id\",\"email\",...]'),\n * graph: \"base64url_encoded_binary_blob...\"\n * }\n * ```\n */\n\nimport type {\n InputEdgeData,\n InputNodeData,\n OutputEdgeData,\n OutputNodeData,\n ParamGraphData,\n RootEntryData,\n} from './types'\n\n/**\n * Serialized format stored in the generated client.\n */\nexport interface SerializedParamGraph {\n /** String table (field names, enum names, root keys) */\n strings: string[]\n /** Base64url-encoded binary blob for structural data */\n graph: string\n}\n\n/**\n * Serializes a ParamGraphData to the compact binary format.\n */\nexport function serializeParamGraph(data: ParamGraphData): SerializedParamGraph {\n return new Serializer(data).serialize()\n}\n\n/**\n * Deserializes a binary-encoded ParamGraph.\n */\nexport function deserializeParamGraph(serialized: SerializedParamGraph): ParamGraphData {\n return new Deserializer(serialized).deserialize()\n}\n\nfunction encodeBase64url(bytes: Uint8Array): string {\n return Buffer.from(bytes.buffer, bytes.byteOffset, bytes.byteLength).toString('base64url')\n}\n\nfunction decodeBase64url(str: string): Uint8Array {\n return Buffer.from(str, 'base64url')\n}\n\n/**\n * Calculates the number of bytes needed to encode a value as an unsigned LEB128 varint.\n */\nfunction varuintSize(value: number): number {\n let size = 1\n while (value >= 0x80) {\n size++\n value >>>= 7\n }\n return size\n}\n\nclass Serializer {\n #data: ParamGraphData\n #buffer: ArrayBuffer\n #view: DataView\n #offset: number = 0\n #rootKeys: string[]\n\n constructor(data: ParamGraphData) {\n this.#data = data\n this.#rootKeys = Object.keys(data.roots)\n\n const size = this.#calculateBufferSize()\n this.#buffer = new ArrayBuffer(size)\n this.#view = new DataView(this.#buffer)\n }\n\n serialize(): SerializedParamGraph {\n this.#writeHeader()\n this.#writeInputNodes()\n this.#writeOutputNodes()\n this.#writeRoots()\n\n return {\n strings: this.#data.strings,\n graph: encodeBase64url(new Uint8Array(this.#buffer, 0, this.#offset)),\n }\n }\n\n #writeVaruint(value: number): void {\n while (value >= 0x80) {\n this.#view.setUint8(this.#offset++, (value & 0x7f) | 0x80)\n value >>>= 7\n }\n this.#view.setUint8(this.#offset++, value)\n }\n\n #writeOptionalVaruint(value: number | undefined): void {\n this.#writeVaruint(value === undefined ? 0 : value + 1)\n }\n\n #writeByte(value: number): void {\n this.#view.setUint8(this.#offset, value)\n this.#offset += 1\n }\n\n #writeU16(value: number): void {\n this.#view.setUint16(this.#offset, value, true)\n this.#offset += 2\n }\n\n #calculateBufferSize(): number {\n let size = 0\n\n // Header: 3 varints\n size += varuintSize(this.#data.inputNodes.length)\n size += varuintSize(this.#data.outputNodes.length)\n size += varuintSize(this.#rootKeys.length)\n\n for (const node of this.#data.inputNodes) {\n const fieldIndices = Object.keys(node.edges).map(Number)\n size += varuintSize(fieldIndices.length)\n\n for (const fieldIndex of fieldIndices) {\n const edge = node.edges[fieldIndex]\n size += varuintSize(fieldIndex)\n size += 2 // scalarMask: u16\n size += varuintSize(edge.childNodeId === undefined ? 0 : edge.childNodeId + 1)\n size += varuintSize(edge.enumNameIndex === undefined ? 0 : edge.enumNameIndex + 1)\n size += 1 // flags: u8\n }\n }\n\n for (const node of this.#data.outputNodes) {\n const fieldIndices = Object.keys(node.edges).map(Number)\n size += varuintSize(fieldIndices.length)\n\n for (const fieldIndex of fieldIndices) {\n const edge = node.edges[fieldIndex]\n size += varuintSize(fieldIndex)\n size += varuintSize(edge.argsNodeId === undefined ? 0 : edge.argsNodeId + 1)\n size += varuintSize(edge.outputNodeId === undefined ? 0 : edge.outputNodeId + 1)\n }\n }\n\n for (const key of this.#rootKeys) {\n const root = this.#data.roots[key]\n const keyIndex = this.#data.strings.indexOf(key)\n size += varuintSize(keyIndex)\n size += varuintSize(root.argsNodeId === undefined ? 0 : root.argsNodeId + 1)\n size += varuintSize(root.outputNodeId === undefined ? 0 : root.outputNodeId + 1)\n }\n\n return size\n }\n\n #writeHeader(): void {\n this.#writeVaruint(this.#data.inputNodes.length)\n this.#writeVaruint(this.#data.outputNodes.length)\n this.#writeVaruint(this.#rootKeys.length)\n }\n\n #writeInputNodes(): void {\n for (const node of this.#data.inputNodes) {\n const fieldIndices = Object.keys(node.edges).map(Number)\n this.#writeVaruint(fieldIndices.length)\n\n for (const fieldIndex of fieldIndices) {\n const edge = node.edges[fieldIndex]\n\n this.#writeVaruint(fieldIndex)\n this.#writeU16(edge.scalarMask ?? 0)\n this.#writeOptionalVaruint(edge.childNodeId)\n this.#writeOptionalVaruint(edge.enumNameIndex)\n this.#writeByte(edge.flags)\n }\n }\n }\n\n #writeOutputNodes(): void {\n for (const node of this.#data.outputNodes) {\n const fieldIndices = Object.keys(node.edges).map(Number)\n this.#writeVaruint(fieldIndices.length)\n\n for (const fieldIndex of fieldIndices) {\n const edge = node.edges[fieldIndex]\n\n this.#writeVaruint(fieldIndex)\n this.#writeOptionalVaruint(edge.argsNodeId)\n this.#writeOptionalVaruint(edge.outputNodeId)\n }\n }\n }\n\n #writeRoots(): void {\n for (const key of this.#rootKeys) {\n const root = this.#data.roots[key]\n const keyIndex = this.#data.strings.indexOf(key)\n if (keyIndex === -1) {\n throw new Error(`Root key \"${key}\" not found in strings table`)\n }\n\n this.#writeVaruint(keyIndex)\n this.#writeOptionalVaruint(root.argsNodeId)\n this.#writeOptionalVaruint(root.outputNodeId)\n }\n }\n}\n\nclass Deserializer {\n #serialized: SerializedParamGraph\n #view: DataView\n #offset: number = 0\n\n constructor(serialized: SerializedParamGraph) {\n this.#serialized = serialized\n const bytes = decodeBase64url(serialized.graph)\n this.#view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength)\n }\n\n deserialize(): ParamGraphData {\n const { inputNodeCount, outputNodeCount, rootCount } = this.#readHeader()\n const inputNodes = this.#readInputNodes(inputNodeCount)\n const outputNodes = this.#readOutputNodes(outputNodeCount)\n const roots = this.#readRoots(rootCount)\n\n return {\n strings: this.#serialized.strings,\n inputNodes,\n outputNodes,\n roots,\n }\n }\n\n #readVaruint(): number {\n let value = 0\n let shift = 0\n let byte: number\n do {\n byte = this.#view.getUint8(this.#offset++)\n value |= (byte & 0x7f) << shift\n shift += 7\n } while (byte >= 0x80)\n return value\n }\n\n #readOptionalVaruint(): number | undefined {\n const value = this.#readVaruint()\n return value === 0 ? undefined : value - 1\n }\n\n #readByte(): number {\n const value = this.#view.getUint8(this.#offset)\n this.#offset += 1\n return value\n }\n\n #readU16(): number {\n const value = this.#view.getUint16(this.#offset, true)\n this.#offset += 2\n return value\n }\n\n #readHeader(): { inputNodeCount: number; outputNodeCount: number; rootCount: number } {\n const inputNodeCount = this.#readVaruint()\n const outputNodeCount = this.#readVaruint()\n const rootCount = this.#readVaruint()\n\n return { inputNodeCount, outputNodeCount, rootCount }\n }\n\n #readInputNodes(count: number): InputNodeData[] {\n const inputNodes: InputNodeData[] = []\n\n for (let i = 0; i < count; i++) {\n const edgeCount = this.#readVaruint()\n const edges: Record<number, InputEdgeData> = {}\n\n for (let j = 0; j < edgeCount; j++) {\n const fieldIndex = this.#readVaruint()\n const scalarMask = this.#readU16()\n const childNodeId = this.#readOptionalVaruint()\n const enumNameIndex = this.#readOptionalVaruint()\n const flags = this.#readByte()\n\n const edge: InputEdgeData = { flags }\n if (scalarMask !== 0) edge.scalarMask = scalarMask\n if (childNodeId !== undefined) edge.childNodeId = childNodeId\n if (enumNameIndex !== undefined) edge.enumNameIndex = enumNameIndex\n\n edges[fieldIndex] = edge\n }\n\n inputNodes.push({ edges })\n }\n\n return inputNodes\n }\n\n #readOutputNodes(count: number): OutputNodeData[] {\n const outputNodes: OutputNodeData[] = []\n\n for (let i = 0; i < count; i++) {\n const edgeCount = this.#readVaruint()\n const edges: Record<number, OutputEdgeData> = {}\n\n for (let j = 0; j < edgeCount; j++) {\n const fieldIndex = this.#readVaruint()\n const argsNodeId = this.#readOptionalVaruint()\n const outputNodeId = this.#readOptionalVaruint()\n\n const edge: OutputEdgeData = {}\n if (argsNodeId !== undefined) edge.argsNodeId = argsNodeId\n if (outputNodeId !== undefined) edge.outputNodeId = outputNodeId\n\n edges[fieldIndex] = edge\n }\n\n outputNodes.push({ edges })\n }\n\n return outputNodes\n }\n\n #readRoots(count: number): Record<string, RootEntryData> {\n const roots: Record<string, RootEntryData> = {}\n\n for (let i = 0; i < count; i++) {\n const keyIndex = this.#readVaruint()\n const argsNodeId = this.#readOptionalVaruint()\n const outputNodeId = this.#readOptionalVaruint()\n\n const key = this.#serialized.strings[keyIndex]\n const root: RootEntryData = {}\n if (argsNodeId !== undefined) root.argsNodeId = argsNodeId\n if (outputNodeId !== undefined) root.outputNodeId = outputNodeId\n\n roots[key] = root\n }\n\n return roots\n }\n}\n", "/**\n * ParamGraph: Runtime class for schema-aware parameterization.\n *\n * This class provides a readable API for navigating the param graph structure\n * at runtime. It's created once per PrismaClient instance from the serialized\n * format embedded in the generated client.\n */\n\nimport type { SerializedParamGraph } from './serialization'\nimport { deserializeParamGraph } from './serialization'\nimport type {\n InputEdgeData,\n InputNodeData,\n OutputEdgeData,\n OutputNodeData,\n ParamGraphData,\n RootEntryData,\n} from './types'\n\n/**\n * Function type for looking up enum values by name.\n * This allows ParamGraph to remain decoupled from RuntimeDataModel.\n */\nexport type EnumLookup = (enumName: string) => readonly string[] | undefined\n\n/**\n * Readable view of root entry.\n */\nexport interface RootEntry {\n readonly argsNodeId: number | undefined\n readonly outputNodeId: number | undefined\n}\n\n/**\n * Readable view of input node.\n */\nexport interface InputNode {\n readonly id: number\n}\n\n/**\n * Readable view of output node.\n */\nexport interface OutputNode {\n readonly id: number\n}\n\n/**\n * Readable view of input edge.\n */\nexport interface InputEdge {\n readonly flags: number\n readonly childNodeId: number | undefined\n readonly scalarMask: number\n readonly enumNameIndex: number | undefined\n}\n\n/**\n * Readable view of output edge.\n */\nexport interface OutputEdge {\n readonly argsNodeId: number | undefined\n readonly outputNodeId: number | undefined\n}\n\n/**\n * ParamGraph provides runtime access to the schema information\n * needed for parameterization decisions.\n */\nexport class ParamGraph {\n readonly #data: ParamGraphData\n readonly #stringIndex: Map<string, number>\n readonly #enumLookup: EnumLookup\n\n private constructor(data: ParamGraphData, enumLookup: EnumLookup) {\n this.#data = data\n this.#enumLookup = enumLookup\n\n // Build string-to-index map for O(1) lookups\n this.#stringIndex = new Map<string, number>()\n for (let i = 0; i < data.strings.length; i++) {\n this.#stringIndex.set(data.strings[i], i)\n }\n }\n\n /**\n * Creates a ParamGraph from serialized format.\n * This is the primary factory method for runtime use.\n */\n static deserialize(serialized: SerializedParamGraph, enumLookup: EnumLookup): ParamGraph {\n const data = deserializeParamGraph(serialized)\n return new ParamGraph(data, enumLookup)\n }\n\n /**\n * Creates a ParamGraph from builder data.\n * Used by the builder for testing and direct construction.\n */\n static fromData(data: ParamGraphData, enumLookup: EnumLookup): ParamGraph {\n return new ParamGraph(data, enumLookup)\n }\n\n /**\n * Look up a root entry by \"Model.action\" or \"action\".\n */\n root(key: string): RootEntry | undefined {\n const entry = this.#data.roots[key]\n if (!entry) {\n return undefined\n }\n return {\n argsNodeId: entry.argsNodeId,\n outputNodeId: entry.outputNodeId,\n }\n }\n\n /**\n * Get an input node by ID.\n */\n inputNode(id: number | undefined): InputNode | undefined {\n if (id === undefined || id < 0 || id >= this.#data.inputNodes.length) {\n return undefined\n }\n return { id }\n }\n\n /**\n * Get an output node by ID.\n */\n outputNode(id: number | undefined): OutputNode | undefined {\n if (id === undefined || id < 0 || id >= this.#data.outputNodes.length) {\n return undefined\n }\n return { id }\n }\n\n /**\n * Get an input edge for a field name within a node.\n */\n inputEdge(node: InputNode | undefined, fieldName: string): InputEdge | undefined {\n if (!node) {\n return undefined\n }\n\n const nodeData = this.#data.inputNodes[node.id]\n if (!nodeData) {\n return undefined\n }\n\n const fieldIndex = this.#stringIndex.get(fieldName)\n if (fieldIndex === undefined) {\n return undefined\n }\n\n const edge = nodeData.edges[fieldIndex]\n if (!edge) {\n return undefined\n }\n\n return {\n flags: edge.flags,\n childNodeId: edge.childNodeId,\n scalarMask: edge.scalarMask ?? 0,\n enumNameIndex: edge.enumNameIndex,\n }\n }\n\n /**\n * Get an output edge for a field name within a node.\n */\n outputEdge(node: OutputNode | undefined, fieldName: string): OutputEdge | undefined {\n if (!node) {\n return undefined\n }\n\n const nodeData = this.#data.outputNodes[node.id]\n if (!nodeData) {\n return undefined\n }\n\n const fieldIndex = this.#stringIndex.get(fieldName)\n if (fieldIndex === undefined) {\n return undefined\n }\n\n const edge = nodeData.edges[fieldIndex]\n if (!edge) {\n return undefined\n }\n\n return {\n argsNodeId: edge.argsNodeId,\n outputNodeId: edge.outputNodeId,\n }\n }\n\n /**\n * Get enum values for an edge that references a user enum.\n * Returns undefined if the edge doesn't reference an enum.\n */\n enumValues(edge: InputEdge | undefined): readonly string[] | undefined {\n if (edge?.enumNameIndex === undefined) {\n return undefined\n }\n\n const enumName = this.#data.strings[edge.enumNameIndex]\n if (!enumName) {\n return undefined\n }\n\n return this.#enumLookup(enumName)\n }\n\n /**\n * Get a string from the string table by index.\n */\n getString(index: number): string | undefined {\n return this.#data.strings[index]\n }\n}\n\n/**\n * Bit flags for InputEdge.flags describing what the field accepts.\n */\nexport const EdgeFlag = {\n /**\n * Field may be parameterized as a scalar value.\n * Check ScalarMask to validate the value type.\n */\n ParamScalar: 1,\n\n /**\n * Field may be parameterized as an enum.\n * Check enum ID to validate the value type.\n */\n ParamEnum: 2,\n\n /**\n * Field accepts list-of-scalar values.\n * Parameterize the whole list if all elements match ScalarMask.\n */\n ParamListScalar: 4,\n\n /**\n * Field accepts list-of-enum values.\n * Parameterize the whole list if all elements match enum ID.\n */\n ParamListEnum: 8,\n\n /**\n * Field accepts list-of-object values.\n * Recurse into each element using the child node.\n */\n ListObject: 16,\n\n /**\n * Field accepts object values.\n * Recurse into child input node.\n */\n Object: 32,\n} as const\n\nexport type EdgeFlagValue = (typeof EdgeFlag)[keyof typeof EdgeFlag]\n\n/**\n * Bit mask for scalar type categories.\n * Used in InputEdge.scalarMask to validate runtime value types.\n */\nexport const ScalarMask = {\n String: 1,\n Int: 2,\n BigInt: 4,\n Float: 8,\n Decimal: 16,\n Boolean: 32,\n DateTime: 64,\n Json: 128,\n Bytes: 256,\n} as const\n\nexport type ScalarMaskValue = (typeof ScalarMask)[keyof typeof ScalarMask]\n\n/**\n * Helper function to check if an edge has a specific flag.\n */\nexport function hasFlag(edge: InputEdge, flag: number): boolean {\n return (edge.flags & flag) !== 0\n}\n\n/**\n * Helper function to get the scalar mask from an edge.\n */\nexport function getScalarMask(edge: InputEdge): number {\n return edge.scalarMask\n}\n\n/**\n * Maps DMMF scalar type names to ScalarMask values.\n */\nexport function scalarTypeToMask(typeName: string): number {\n switch (typeName) {\n case 'String':\n case 'UUID':\n return ScalarMask.String\n case 'Int':\n return ScalarMask.Int\n case 'BigInt':\n return ScalarMask.BigInt\n case 'Float':\n return ScalarMask.Float\n case 'Decimal':\n return ScalarMask.Decimal\n case 'Boolean':\n return ScalarMask.Boolean\n case 'DateTime':\n return ScalarMask.DateTime\n case 'Json':\n return ScalarMask.Json\n case 'Bytes':\n return ScalarMask.Bytes\n default:\n return 0\n }\n}\n\n// Re-export data types for builder use\nexport type { InputEdgeData, InputNodeData, OutputEdgeData, OutputNodeData, ParamGraphData, RootEntryData }\n", "{\n \"name\": \"@prisma/client\",\n \"version\": \"7.4.0-integration-parameterization.21\",\n \"description\": \"Prisma Client is an auto-generated, type-safe and modern JavaScript/TypeScript ORM for Node.js that's tailored to your data. Supports PostgreSQL, CockroachDB, MySQL, MariaDB, SQL Server, SQLite & MongoDB databases.\",\n \"keywords\": [\n \"ORM\",\n \"Prisma\",\n \"prisma2\",\n \"Prisma Client\",\n \"client\",\n \"query\",\n \"query-builder\",\n \"database\",\n \"db\",\n \"JavaScript\",\n \"JS\",\n \"TypeScript\",\n \"TS\",\n \"SQL\",\n \"SQLite\",\n \"pg\",\n \"Postgres\",\n \"PostgreSQL\",\n \"CockroachDB\",\n \"MySQL\",\n \"MariaDB\",\n \"MSSQL\",\n \"SQL Server\",\n \"SQLServer\",\n \"MongoDB\"\n ],\n \"main\": \"default.js\",\n \"types\": \"default.d.ts\",\n \"browser\": \"index-browser.js\",\n \"exports\": {\n \"./package.json\": \"./package.json\",\n \".\": {\n \"require\": {\n \"types\": \"./default.d.ts\",\n \"node\": \"./default.js\",\n \"edge-light\": \"./default.js\",\n \"workerd\": \"./default.js\",\n \"worker\": \"./default.js\",\n \"browser\": \"./index-browser.js\"\n },\n \"import\": {\n \"types\": \"./default.d.ts\",\n \"node\": \"./default.js\",\n \"edge-light\": \"./default.js\",\n \"workerd\": \"./default.js\",\n \"worker\": \"./default.js\",\n \"browser\": \"./index-browser.js\"\n },\n \"default\": \"./default.js\"\n },\n \"./extension\": {\n \"types\": \"./extension.d.ts\",\n \"require\": \"./extension.js\",\n \"import\": \"./extension.js\",\n \"default\": \"./extension.js\"\n },\n \"./index-browser\": {\n \"types\": \"./index.d.ts\",\n \"require\": \"./index-browser.js\",\n \"import\": \"./index-browser.js\",\n \"default\": \"./index-browser.js\"\n },\n \"./index\": {\n \"types\": \"./index.d.ts\",\n \"require\": \"./index.js\",\n \"import\": \"./index.js\",\n \"default\": \"./index.js\"\n },\n \"./edge\": {\n \"types\": \"./edge.d.ts\",\n \"require\": \"./edge.js\",\n \"import\": \"./edge.js\",\n \"default\": \"./edge.js\"\n },\n \"./runtime/client\": {\n \"types\": \"./runtime/client.d.ts\",\n \"node\": {\n \"require\": \"./runtime/client.js\",\n \"default\": \"./runtime/client.js\"\n },\n \"require\": \"./runtime/client.js\",\n \"import\": \"./runtime/client.mjs\",\n \"default\": \"./runtime/client.mjs\"\n },\n \"./runtime/wasm-compiler-edge\": {\n \"types\": \"./runtime/wasm-compiler-edge.d.ts\",\n \"require\": \"./runtime/wasm-compiler-edge.js\",\n \"import\": \"./runtime/wasm-compiler-edge.mjs\",\n \"default\": \"./runtime/wasm-compiler-edge.mjs\"\n },\n \"./runtime/index-browser\": {\n \"types\": \"./runtime/index-browser.d.ts\",\n \"require\": \"./runtime/index-browser.js\",\n \"import\": \"./runtime/index-browser.mjs\",\n \"default\": \"./runtime/index-browser.mjs\"\n },\n \"./generator-build\": {\n \"require\": \"./generator-build/index.js\",\n \"import\": \"./generator-build/index.js\",\n \"default\": \"./generator-build/index.js\"\n },\n \"./sql\": {\n \"require\": {\n \"types\": \"./sql.d.ts\",\n \"node\": \"./sql.js\",\n \"default\": \"./sql.js\"\n },\n \"import\": {\n \"types\": \"./sql.d.ts\",\n \"node\": \"./sql.mjs\",\n \"default\": \"./sql.mjs\"\n },\n \"default\": \"./sql.js\"\n },\n \"./*\": \"./*\"\n },\n \"license\": \"Apache-2.0\",\n \"engines\": {\n \"node\": \"^20.19 || ^22.12 || >=24.0\"\n },\n \"homepage\": \"https://www.prisma.io\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/prisma/prisma.git\",\n \"directory\": \"packages/client\"\n },\n \"author\": \"Tim Suchanek <suchanek@prisma.io>\",\n \"bugs\": \"https://github.com/prisma/prisma/issues\",\n \"scripts\": {\n \"dev\": \"DEV=true tsx helpers/build.ts\",\n \"build\": \"tsx helpers/build.ts\",\n \"test\": \"dotenv -e ../../.db.env -- jest --silent\",\n \"test:e2e\": \"dotenv -e ../../.db.env -- tsx tests/e2e/_utils/run.ts\",\n \"test:functional\": \"dotenv -e ../../.db.env -- tsx helpers/functional-test/run-tests.ts\",\n \"test:functional:client\": \"pnpm run test:functional --client-runtime client\",\n \"test:memory\": \"dotenv -e ../../.db.env -- tsx helpers/memory-tests.ts\",\n \"test:functional:code\": \"dotenv -e ../../.db.env -- tsx helpers/functional-test/run-tests.ts --no-types\",\n \"test:functional:types\": \"dotenv -e ../../.db.env -- tsx helpers/functional-test/run-tests.ts --types-only\",\n \"test-notypes\": \"dotenv -e ../../.db.env -- jest --testPathIgnorePatterns src/__tests__/types/types.test.ts\",\n \"prepublishOnly\": \"pnpm run build\",\n \"new-test\": \"tsx ./helpers/new-test/new-test.ts\"\n },\n \"files\": [\n \"README.md\",\n \"runtime\",\n \"scripts\",\n \"generator-build\",\n \"edge.js\",\n \"edge.d.ts\",\n \"index.js\",\n \"index.d.ts\",\n \"default.js\",\n \"default.d.ts\",\n \"index-browser.js\",\n \"extension.js\",\n \"extension.d.ts\",\n \"sql.d.ts\",\n \"sql.js\",\n \"sql.mjs\"\n ],\n \"devDependencies\": {\n \"@cloudflare/workers-types\": \"^4.20251014.0\",\n \"@codspeed/benchmark.js-plugin\": \"4.0.0\",\n \"@faker-js/faker\": \"9.6.0\",\n \"@fast-check/jest\": \"2.0.3\",\n \"@hono/node-server\": \"1.19.0\",\n \"@inquirer/prompts\": \"7.3.3\",\n \"@jest/create-cache-key-function\": \"29.7.0\",\n \"@jest/globals\": \"29.7.0\",\n \"@jest/test-sequencer\": \"29.7.0\",\n \"@libsql/client\": \"0.8.1\",\n \"@neondatabase/serverless\": \"0.10.2\",\n \"@opentelemetry/api\": \"1.9.0\",\n \"@opentelemetry/context-async-hooks\": \"2.1.0\",\n \"@opentelemetry/instrumentation\": \"0.206.0\",\n \"@opentelemetry/resources\": \"2.1.0\",\n \"@opentelemetry/sdk-trace-base\": \"2.1.0\",\n \"@opentelemetry/semantic-conventions\": \"1.37.0\",\n \"@planetscale/database\": \"1.19.0\",\n \"@prisma/adapter-better-sqlite3\": \"workspace:*\",\n \"@prisma/adapter-d1\": \"workspace:*\",\n \"@prisma/adapter-libsql\": \"workspace:*\",\n \"@prisma/adapter-mariadb\": \"workspace:*\",\n \"@prisma/adapter-mssql\": \"workspace:*\",\n \"@prisma/adapter-neon\": \"workspace:*\",\n \"@prisma/adapter-pg\": \"workspace:*\",\n \"@prisma/adapter-planetscale\": \"workspace:*\",\n \"@prisma/client-common\": \"workspace:*\",\n \"@prisma/client-engine-runtime\": \"workspace:*\",\n \"@prisma/client-generator-js\": \"workspace:*\",\n \"@prisma/client-generator-ts\": \"workspace:*\",\n \"@prisma/config\": \"workspace:*\",\n \"@prisma/debug\": \"workspace:*\",\n \"@prisma/dmmf\": \"workspace:*\",\n \"@prisma/driver-adapter-utils\": \"workspace:*\",\n \"@prisma/engines\": \"workspace:*\",\n \"@prisma/engines-version\": \"7.4.0-8.534ac5c12b9088d160899554cc8c11039ffb9738\",\n \"@prisma/fetch-engine\": \"workspace:*\",\n \"@prisma/generator\": \"workspace:*\",\n \"@prisma/generator-helper\": \"workspace:*\",\n \"@prisma/get-platform\": \"workspace:*\",\n \"@prisma/instrumentation\": \"workspace:*\",\n \"@prisma/instrumentation-contract\": \"workspace:*\",\n \"@prisma/internals\": \"workspace:*\",\n \"@prisma/json-protocol\": \"workspace:*\",\n \"@prisma/migrate\": \"workspace:*\",\n \"@prisma/query-compiler-wasm\": \"7.4.0-8.534ac5c12b9088d160899554cc8c11039ffb9738\",\n \"@prisma/param-graph\": \"workspace:*\",\n \"@prisma/param-graph-builder\": \"workspace:*\",\n \"@prisma/query-plan-executor\": \"workspace:*\",\n \"@prisma/sqlcommenter\": \"workspace:*\",\n \"@prisma/sqlcommenter-trace-context\": \"workspace:*\",\n \"@prisma/ts-builders\": \"workspace:*\",\n \"@snaplet/copycat\": \"6.0.0\",\n \"@swc-node/register\": \"1.10.9\",\n \"@swc/core\": \"1.11.5\",\n \"@swc/jest\": \"0.2.37\",\n \"@timsuchanek/copy\": \"1.4.5\",\n \"@types/debug\": \"4.1.12\",\n \"@types/fs-extra\": \"11.0.4\",\n \"@types/jest\": \"29.5.14\",\n \"@types/js-levenshtein\": \"1.1.3\",\n \"@types/mssql\": \"9.1.8\",\n \"@types/node\": \"~20.19.24\",\n \"@types/pg\": \"8.11.11\",\n \"arg\": \"5.0.2\",\n \"benchmark\": \"2.1.4\",\n \"cookie-es\": \"2.0.0\",\n \"execa\": \"8.0.1\",\n \"expect-type\": \"1.2.2\",\n \"fs-extra\": \"11.3.0\",\n \"get-stream\": \"6.0.1\",\n \"globby\": \"11.1.0\",\n \"indent-string\": \"4.0.0\",\n \"jest\": \"29.7.0\",\n \"jest-extended\": \"4.0.2\",\n \"jest-junit\": \"16.0.0\",\n \"jest-serializer-ansi-escapes\": \"4.0.0\",\n \"jest-snapshot\": \"29.7.0\",\n \"js-levenshtein\": \"1.1.6\",\n \"kleur\": \"4.1.5\",\n \"klona\": \"2.0.6\",\n \"mariadb\": \"3.4.5\",\n \"memfs\": \"4.17.2\",\n \"mssql\": \"11.0.1\",\n \"new-github-issue-url\": \"0.2.1\",\n \"p-retry\": \"4.6.2\",\n \"pg\": \"8.14.1\",\n \"resolve\": \"1.22.10\",\n \"simple-statistics\": \"7.8.8\",\n \"sort-keys\": \"5.1.0\",\n \"source-map-support\": \"0.5.21\",\n \"stacktrace-parser\": \"0.1.11\",\n \"strip-ansi\": \"7.1.0\",\n \"strip-indent\": \"4.0.0\",\n \"tempy\": \"3.0.0\",\n \"ts-pattern\": \"5.6.2\",\n \"tsd\": \"0.31.2\",\n \"typescript\": \"5.4.5\",\n \"undici\": \"7.4.0\",\n \"zx\": \"8.4.1\"\n },\n \"dependencies\": {\n \"@prisma/client-runtime-utils\": \"workspace:*\"\n },\n \"peerDependencies\": {\n \"prisma\": \"*\",\n \"typescript\": \">=5.4.0\"\n },\n \"peerDependenciesMeta\": {\n \"prisma\": {\n \"optional\": true\n },\n \"typescript\": {\n \"optional\": true\n }\n },\n \"sideEffects\": false\n}", "import type { PrismaValue } from '@prisma/client-engine-runtime'\nimport type { ArgScalarType, ArgType } from '@prisma/driver-adapter-utils'\n\ntype RawParameters = {\n args: PrismaValue[]\n argTypes: ArgType[]\n}\n\nconst tagToArgScalarType: Record<string, ArgScalarType> = {\n bigint: 'bigint',\n date: 'datetime',\n decimal: 'decimal',\n bytes: 'bytes',\n}\n\nexport function deserializeRawParameters(serializedParameters: string): RawParameters {\n let parsed: unknown\n try {\n parsed = JSON.parse(serializedParameters)\n } catch (err) {\n throw new Error(`Received invalid serialized parameters: ${err.message}`)\n }\n if (!Array.isArray(parsed)) {\n throw new Error('Received invalid serialized parameters: expected an array')\n }\n const args = parsed.map((parameter: unknown) => decodeParameter(parameter))\n const argTypes = parsed.map((parameter: unknown) => getArgType(parameter))\n return { args, argTypes }\n}\n\nfunction decodeParameter(parameter: unknown): PrismaValue {\n if (Array.isArray(parameter)) {\n return parameter.map((item) => decodeParameter(item))\n }\n\n if (typeof parameter === 'object' && parameter !== null && 'prisma__value' in parameter) {\n if (!('prisma__type' in parameter)) {\n throw new Error('Invalid serialized parameter, prisma__type should be present when prisma__value is present')\n }\n return `${parameter.prisma__value}`\n }\n\n if (typeof parameter === 'object' && parameter !== null) {\n return JSON.stringify(parameter)\n }\n\n return parameter as PrismaValue\n}\n\nfunction getArgType(parameter: unknown): ArgType {\n if (Array.isArray(parameter)) {\n return { scalarType: parameter.length > 0 ? getScalarType(parameter[0]) : 'unknown', arity: 'list' }\n }\n\n return { scalarType: getScalarType(parameter), arity: 'scalar' }\n}\n\nfunction getScalarType(parameter: unknown): ArgScalarType {\n if (\n typeof parameter === 'object' &&\n parameter !== null &&\n 'prisma__type' in parameter &&\n typeof parameter.prisma__type === 'string' &&\n parameter.prisma__type in tagToArgScalarType\n ) {\n return tagToArgScalarType[parameter.prisma__type]\n }\n\n if (typeof parameter === 'number') {\n return 'decimal'\n }\n\n if (typeof parameter === 'string') {\n return 'string'\n }\n\n return 'unknown'\n}\n", "import type { JsonBatchQuery, JsonQuery } from '@prisma/json-protocol'\n\nimport { TransactionOptions } from '../Engine'\n\nexport function getBatchRequestPayload(batch: JsonQuery[], transaction?: TransactionOptions<unknown>): JsonBatchQuery {\n return {\n batch,\n transaction: transaction?.kind === 'batch' ? { isolationLevel: transaction.options.isolationLevel } : undefined,\n }\n}\n", "export function maskQuery(query?: string): string {\n if (!query) {\n return ''\n }\n return (\n query\n // replace all strings with X\n .replace(/\".*\"/g, '\"X\"')\n // replace all numbers with 5\n .replace(/[\\s:\\[]([+-]?([0-9]*[.])?[0-9]+)/g, (substr) => {\n return `${substr[0]}5`\n })\n )\n}\n", "/**\n * Removes the leading timestamps (from docker) and trailing ms (from debug)\n * @param logs logs to normalize\n */\nexport function normalizeLogs(logs: string): string {\n return logs\n .split('\\n')\n .map((l) => {\n return l\n .replace(/^\\d{4}-[01]\\d-[0-3]\\dT[0-2]\\d:[0-5]\\d:[0-5]\\d\\.\\d+([+-][0-2]\\d:[0-5]\\d|Z)\\s*/, '')\n .replace(/\\+\\d+\\s*ms$/, '')\n })\n .join('\\n')\n}\n", "import newGitHubIssueUrl from 'new-github-issue-url'\n\nexport function getGitHubIssueUrl({\n title,\n user = 'prisma',\n repo = 'prisma',\n template = 'bug_report.yml',\n body,\n}: {\n title: string\n user?: string\n repo?: string\n template?: string\n body?: string\n}): string {\n return newGitHubIssueUrl({\n user,\n repo,\n template,\n title,\n body,\n })\n}\n", "import { getLogs } from '@prisma/debug'\nimport { underline } from 'kleur/colors'\nimport stripAnsi from 'strip-ansi'\n\nimport type { ErrorWithLinkInput } from '../types/ErrorWithLinkInput'\nimport { maskQuery } from './maskQuery'\nimport { normalizeLogs } from './normalizeLogs'\nimport { getGitHubIssueUrl } from './util'\n\nexport function getErrorMessageWithLink({\n version,\n binaryTarget,\n title,\n description,\n engineVersion,\n database,\n query,\n}: ErrorWithLinkInput) {\n const gotLogs = getLogs(6000 - (query?.length ?? 0))\n const logs = normalizeLogs(stripAnsi(gotLogs))\n const moreInfo = description ? `# Description\\n\\`\\`\\`\\n${description}\\n\\`\\`\\`` : ''\n const body = stripAnsi(\n `Hi Prisma Team! My Prisma Client just crashed. This is the report:\n## Versions\n\n| Name | Version |\n|-----------------|--------------------|\n| Node | ${process.version?.padEnd(19)}| \n| OS | ${binaryTarget?.padEnd(19)}|\n| Prisma Client | ${version?.padEnd(19)}|\n| Query Engine | ${engineVersion?.padEnd(19)}|\n| Database | ${database?.padEnd(19)}|\n\n${moreInfo}\n\n## Logs\n\\`\\`\\`\n${logs}\n\\`\\`\\`\n\n## Client Snippet\n\\`\\`\\`ts\n// PLEASE FILL YOUR CODE SNIPPET HERE\n\\`\\`\\`\n\n## Schema\n\\`\\`\\`prisma\n// PLEASE ADD YOUR SCHEMA HERE IF POSSIBLE\n\\`\\`\\`\n\n## Prisma Engine Query\n\\`\\`\\`\n${query ? maskQuery(query) : ''}\n\\`\\`\\`\n`,\n )\n\n const url = getGitHubIssueUrl({ title, body })\n return `${title}\n\nThis is a non-recoverable error which probably happens when the Prisma Query Engine has a panic.\n\n${underline(url)}\n\nIf you want the Prisma team to look into it, please open the link above \uD83D\uDE4F\nTo increase the chance of success, please post your schema and a snippet of\nhow you used Prisma Client in the issue. \n`\n}\n", "import {\n type QueryEvent,\n QueryInterpreter,\n type SchemaProvider,\n type TracingHelper,\n TransactionManager,\n type TransactionOptions,\n} from '@prisma/client-engine-runtime'\nimport type { ConnectionInfo, SqlDriverAdapter, SqlDriverAdapterFactory } from '@prisma/driver-adapter-utils'\nimport type { SqlCommenterPlugin } from '@prisma/sqlcommenter'\n\nimport type { InteractiveTransactionInfo } from '../common/types/Transaction'\nimport type { ExecutePlanParams, Executor, ProviderAndConnectionInfo } from './Executor'\n\nexport interface LocalExecutorOptions {\n driverAdapterFactory: SqlDriverAdapterFactory\n transactionOptions: TransactionOptions\n tracingHelper: TracingHelper\n onQuery?: (event: QueryEvent) => void\n provider?: SchemaProvider\n sqlCommenters?: SqlCommenterPlugin[]\n}\n\nexport class LocalExecutor implements Executor {\n readonly #options: LocalExecutorOptions\n readonly #driverAdapter: SqlDriverAdapter\n readonly #transactionManager: TransactionManager\n readonly #connectionInfo?: ConnectionInfo\n readonly #interpreter: QueryInterpreter\n\n constructor(options: LocalExecutorOptions, driverAdapter: SqlDriverAdapter, transactionManager: TransactionManager) {\n this.#options = options\n this.#driverAdapter = driverAdapter\n this.#transactionManager = transactionManager\n this.#connectionInfo = driverAdapter.getConnectionInfo?.()\n this.#interpreter = QueryInterpreter.forSql({\n onQuery: this.#options.onQuery,\n tracingHelper: this.#options.tracingHelper,\n provider: this.#options.provider,\n connectionInfo: this.#connectionInfo,\n })\n }\n\n static async connect(options: LocalExecutorOptions): Promise<LocalExecutor> {\n let driverAdapter: SqlDriverAdapter | undefined = undefined\n let transactionManager: TransactionManager | undefined = undefined\n\n try {\n driverAdapter = await options.driverAdapterFactory.connect()\n transactionManager = new TransactionManager({\n driverAdapter,\n transactionOptions: options.transactionOptions,\n tracingHelper: options.tracingHelper,\n onQuery: options.onQuery,\n provider: options.provider,\n })\n } catch (error) {\n await driverAdapter?.dispose()\n throw error\n }\n\n return new LocalExecutor(options, driverAdapter, transactionManager)\n }\n\n getConnectionInfo(): Promise<ProviderAndConnectionInfo> {\n const connectionInfo = this.#connectionInfo ?? { supportsRelationJoins: false }\n return Promise.resolve({ provider: this.#driverAdapter.provider, connectionInfo })\n }\n\n async execute({\n plan,\n placeholderValues: scope,\n transaction,\n batchIndex,\n queryInfo,\n }: ExecutePlanParams): Promise<unknown> {\n const queryable = transaction\n ? await this.#transactionManager.getTransaction(transaction, batchIndex !== undefined ? 'batch query' : 'query')\n : this.#driverAdapter\n\n return await this.#interpreter.run(plan, {\n queryable,\n transactionManager: transaction ? { enabled: false } : { enabled: true, manager: this.#transactionManager },\n scope,\n sqlCommenter: this.#options.sqlCommenters && {\n plugins: this.#options.sqlCommenters,\n queryInfo,\n },\n })\n }\n\n async startTransaction(options: TransactionOptions): Promise<InteractiveTransactionInfo> {\n return { ...(await this.#transactionManager.startTransaction(options)), payload: undefined }\n }\n\n async commitTransaction(transaction: InteractiveTransactionInfo): Promise<void> {\n await this.#transactionManager.commitTransaction(transaction.id)\n }\n\n async rollbackTransaction(transaction: InteractiveTransactionInfo): Promise<void> {\n await this.#transactionManager.rollbackTransaction(transaction.id)\n }\n\n async disconnect(): Promise<void> {\n try {\n await this.#transactionManager.cancelAllTransactions()\n } finally {\n await this.#driverAdapter.dispose()\n }\n }\n\n apiKey(): string | null {\n return null\n }\n}\n", "/**\n * Value classification for parameterization.\n *\n * This module classifies runtime values into categories before applying\n * schema rules during parameterization.\n */\n\nimport { JsonInputTaggedValue } from '@prisma/json-protocol'\n\n/**\n * Tagged value types that represent scalar values.\n * These can be parameterized when the schema allows.\n */\nconst SCALAR_TAGS = new Set(['DateTime', 'Decimal', 'BigInt', 'Bytes', 'Json', 'Raw'])\n\n/**\n * Tagged value types that are structural and should never be parameterized.\n * These represent special query constructs that must be preserved as-is.\n */\nconst STRUCTURAL_TAGS = new Set(['FieldRef', 'Enum', 'Param'])\n\n/**\n * Classification result for a runtime value.\n * Used to determine how to handle the value during parameterization.\n */\nexport type ValueClass =\n | { kind: 'null' }\n | { kind: 'primitive'; value: string | number | boolean }\n | { kind: 'taggedScalar'; tag: JsonInputTaggedValue['$type']; value: unknown }\n | { kind: 'structural'; value: unknown }\n | { kind: 'array'; items: unknown[] }\n | { kind: 'object'; entries: Record<string, unknown> }\n\n/**\n * Classifies a runtime value for parameterization purposes.\n *\n * @param value - The value to classify\n * @returns The classification result indicating how to handle the value\n */\nexport function classifyValue(value: unknown): ValueClass {\n if (value === null || value === undefined) {\n return { kind: 'null' }\n }\n\n if (typeof value === 'string') {\n return { kind: 'primitive', value }\n }\n if (typeof value === 'number') {\n return { kind: 'primitive', value }\n }\n if (typeof value === 'boolean') {\n return { kind: 'primitive', value }\n }\n\n if (Array.isArray(value)) {\n return { kind: 'array', items: value }\n }\n\n if (typeof value === 'object') {\n const obj = value as Record<string, unknown>\n\n // Check for tagged value\n if ('$type' in obj && typeof obj.$type === 'string') {\n const tag = obj.$type as JsonInputTaggedValue['$type']\n\n if (SCALAR_TAGS.has(tag)) {\n return { kind: 'taggedScalar', tag, value: obj.value }\n }\n\n if (STRUCTURAL_TAGS.has(tag)) {\n return { kind: 'structural', value: obj.value }\n }\n }\n\n return { kind: 'object', entries: obj }\n }\n\n return { kind: 'structural', value }\n}\n\n/**\n * Checks if a value is a plain object (not a tagged value or array).\n */\nexport function isPlainObject(value: unknown): value is Record<string, unknown> {\n return (\n typeof value === 'object' &&\n value !== null &&\n !Array.isArray(value) &&\n !('$type' in (value as Record<string, unknown>))\n )\n}\n\n/**\n * Checks if a value is a tagged value with a $type property.\n */\nexport function isTaggedValue(value: unknown): value is { $type: string; value: unknown } {\n return (\n typeof value === 'object' &&\n value !== null &&\n '$type' in value &&\n typeof (value as { $type: unknown }).$type === 'string'\n )\n}\n", "/**\n * Schema-aware traversal algorithm for parameterization.\n *\n * This module implements the core parameterization logic that walks the\n * JsonQuery tree guided by ParamGraph. It only parameterizes values when\n * both schema rules and runtime value types agree.\n */\n\nimport type {\n JsonArgumentValue,\n JsonBatchQuery,\n JsonFieldSelection,\n JsonInputTaggedValue,\n JsonQuery,\n JsonSelectionSet,\n PlaceholderTaggedValue,\n} from '@prisma/json-protocol'\nimport { PlaceholderType } from '@prisma/json-protocol'\nimport type { InputEdge, InputNode } from '@prisma/param-graph'\nimport { EdgeFlag, getScalarMask, hasFlag, ParamGraph, ScalarMask } from '@prisma/param-graph'\n\nimport { classifyValue, isPlainObject, isTaggedValue, ValueClass } from './classify'\n\n/**\n * Result of parameterizing a single query.\n */\nexport interface ParameterizeResult {\n /** The query with user data values replaced by placeholders */\n parameterizedQuery: JsonQuery\n /** Map of placeholder names to their actual values */\n placeholderValues: Record<string, unknown>\n}\n\n/**\n * Result of parameterizing a batch of queries.\n */\nexport interface ParameterizeBatchResult {\n /** The batch with user data values replaced by placeholders */\n parameterizedBatch: JsonBatchQuery\n /** Combined map of placeholder names to their actual values */\n placeholderValues: Record<string, unknown>\n}\n\n/**\n * Parameterizes a single query using the schema-aware approach.\n *\n * @param query - The query to parameterize\n * @param view - The ParamGraph for schema lookups\n * @returns The parameterized query with extracted placeholder values\n */\nexport function parameterizeQuery(query: JsonQuery, view: ParamGraph): ParameterizeResult {\n const parameterizer = new Parameterizer(view)\n\n const rootKey = query.modelName ? `${query.modelName}.${query.action}` : query.action\n const root = view.root(rootKey)\n\n const parameterizedQuery: JsonQuery = {\n ...query,\n query: parameterizer.parameterizeFieldSelection(query.query, root?.argsNodeId, root?.outputNodeId),\n }\n\n return {\n parameterizedQuery,\n placeholderValues: parameterizer.getPlaceholderValues(),\n }\n}\n\n/**\n * Parameterizes a batch of queries using the schema-aware approach.\n *\n * @param batch - The batch to parameterize\n * @param view - The ParamGraph for schema lookups\n * @returns The parameterized batch with extracted placeholder values\n */\nexport function parameterizeBatch(batch: JsonBatchQuery, view: ParamGraph): ParameterizeBatchResult {\n const parameterizer = new Parameterizer(view)\n const parameterizedQueries: JsonQuery[] = []\n\n for (let i = 0; i < batch.batch.length; i++) {\n const query = batch.batch[i]\n\n const rootKey = query.modelName ? `${query.modelName}.${query.action}` : query.action\n const root = view.root(rootKey)\n\n parameterizedQueries.push({\n ...query,\n query: parameterizer.parameterizeFieldSelection(query.query, root?.argsNodeId, root?.outputNodeId),\n })\n }\n\n return {\n parameterizedBatch: { ...batch, batch: parameterizedQueries },\n placeholderValues: parameterizer.getPlaceholderValues(),\n }\n}\n\n/**\n * Encapsulates the state and logic for parameterizing queries.\n */\nclass Parameterizer {\n readonly #view: ParamGraph\n readonly #placeholders = new Map<string, unknown>()\n readonly #valueToPlaceholder = new Map<string, string>()\n #nextPlaceholderId = 1\n\n constructor(view: ParamGraph) {\n this.#view = view\n }\n\n /**\n * Returns the collected placeholder values as a plain object.\n */\n getPlaceholderValues(): Record<string, unknown> {\n return Object.fromEntries(this.#placeholders)\n }\n\n /**\n * Gets or creates a placeholder for the given value.\n * If a placeholder already exists for this value, returns a reference to the existing name.\n * Otherwise, registers a new placeholder with a sequential name.\n * We reuse the placeholders for equal values because the query compiler needs to be able\n * to compare the values for equality for certain optimizations (at the time of writing,\n * only for deciding whether to use native or emulated upserts).\n */\n #getOrCreatePlaceholder(value: unknown, type: PlaceholderType): PlaceholderTaggedValue {\n const valueKey = createValueKey(value, type)\n const existingName = this.#valueToPlaceholder.get(valueKey)\n\n if (existingName !== undefined) {\n return createPlaceholder(existingName, type)\n }\n\n const name = `%${this.#nextPlaceholderId++}`\n this.#valueToPlaceholder.set(valueKey, name)\n this.#placeholders.set(name, value)\n return createPlaceholder(name, type)\n }\n\n /**\n * Parameterizes a field selection (arguments + selection).\n */\n parameterizeFieldSelection(\n sel: JsonFieldSelection,\n argsNodeId: number | undefined,\n outNodeId: number | undefined,\n ): JsonFieldSelection {\n const argsNode = this.#view.inputNode(argsNodeId)\n const outNode = this.#view.outputNode(outNodeId)\n\n const result: JsonFieldSelection = { ...sel }\n\n // Process arguments using input node\n if (sel.arguments && sel.arguments.$type !== 'Raw') {\n result.arguments = this.#parameterizeObject(sel.arguments as Record<string, unknown>, argsNode)\n }\n\n // Process selection using output node\n if (sel.selection) {\n result.selection = this.#parameterizeSelection(sel.selection, outNode)\n }\n\n return result\n }\n\n /**\n * Parameterizes an object by traversing its fields with the input node.\n */\n #parameterizeObject(obj: Record<string, unknown>, node: InputNode | undefined): Record<string, JsonArgumentValue> {\n if (!node) {\n // No parameterizable fields in this subtree - return as-is\n return obj as Record<string, JsonArgumentValue>\n }\n\n const result: Record<string, JsonArgumentValue> = {}\n\n for (const [key, value] of Object.entries(obj)) {\n const edge = this.#view.inputEdge(node, key)\n\n if (edge) {\n result[key] = this.#parameterizeValue(value, edge) as JsonArgumentValue\n } else {\n result[key] = value as JsonArgumentValue\n }\n }\n\n return result\n }\n\n /**\n * Core parameterization logic for a single value.\n */\n #parameterizeValue(value: unknown, edge: InputEdge): unknown {\n const classified = classifyValue(value)\n\n switch (classified.kind) {\n case 'null':\n // Null values are never parameterized - they affect query semantics\n return value\n\n case 'structural':\n return value\n\n case 'primitive':\n return this.#handlePrimitive(classified.value, edge)\n\n case 'taggedScalar':\n return this.#handleTaggedScalar(value as JsonInputTaggedValue, classified.tag, edge)\n\n case 'array':\n return this.#handleArray(classified.items, value, edge)\n\n case 'object':\n return this.#handleObject(classified.entries, edge)\n\n default:\n throw new Error(`Unknown value kind ${(classified satisfies never as ValueClass).kind}`)\n }\n }\n\n /**\n * Handles parameterization of primitive values (string, number, boolean).\n */\n #handlePrimitive(value: string | number | boolean, edge: InputEdge): JsonArgumentValue {\n if (hasFlag(edge, EdgeFlag.ParamEnum) && edge.enumNameIndex !== undefined && typeof value === 'string') {\n const enumValues = this.#view.enumValues(edge)\n if (enumValues?.includes(value)) {\n const type: PlaceholderType = { type: 'Enum' }\n return this.#getOrCreatePlaceholder(value, type)\n }\n }\n\n if (!hasFlag(edge, EdgeFlag.ParamScalar)) {\n return value\n }\n\n const mask = getScalarMask(edge)\n if (mask === 0) {\n return value\n }\n\n const type = getPrimitivePlaceholderType(value)\n if (!matchesPrimitiveMask(type, mask)) {\n return value\n }\n\n if (mask & ScalarMask.Json) {\n value = JSON.stringify(value)\n }\n\n return this.#getOrCreatePlaceholder(value, type)\n }\n\n /**\n * Handles parameterization of tagged scalar values (DateTime, Decimal, etc.).\n */\n #handleTaggedScalar(tagged: JsonInputTaggedValue, tag: JsonInputTaggedValue['$type'], edge: InputEdge): unknown {\n if (!hasFlag(edge, EdgeFlag.ParamScalar)) {\n return tagged\n }\n\n const mask = getScalarMask(edge)\n if (mask === 0 || !matchesTaggedMask(tag, mask)) {\n return tagged\n }\n\n const type = getTaggedPlaceholderType(tagged.$type)!\n const decoded = decodeTaggedValue(tagged)\n\n return this.#getOrCreatePlaceholder(decoded, type)\n }\n\n /**\n * Handles parameterization of array values.\n */\n #handleArray(items: unknown[], originalValue: unknown, edge: InputEdge): unknown {\n if (hasFlag(edge, EdgeFlag.ParamScalar) && getScalarMask(edge) & ScalarMask.Json) {\n const jsonValue = JSON.stringify(items)\n const type: PlaceholderType = { type: 'Json' }\n return this.#getOrCreatePlaceholder(jsonValue, type)\n }\n\n if (hasFlag(edge, EdgeFlag.ParamEnum)) {\n const enumValues = this.#view.enumValues(edge)\n if (enumValues && items.every((item) => typeof item === 'string' && enumValues.includes(item))) {\n const type: PlaceholderType = { type: 'List', inner: { type: 'Enum' } }\n return this.#getOrCreatePlaceholder(items, type)\n }\n }\n\n if (hasFlag(edge, EdgeFlag.ParamListScalar)) {\n const allValid = items.every((item) => validateListElement(item, edge))\n if (allValid && items.length > 0) {\n const decodedItems = items.map((item) => decodeIfTagged(item))\n const innerType = inferListElementType(items[0])\n const type: PlaceholderType = { type: 'List', inner: innerType }\n return this.#getOrCreatePlaceholder(decodedItems, type)\n }\n }\n\n if (hasFlag(edge, EdgeFlag.ListObject)) {\n const childNode = this.#view.inputNode(edge.childNodeId)\n if (childNode) {\n return items.map((item) => {\n if (isPlainObject(item)) {\n return this.#parameterizeObject(item, childNode)\n }\n return item\n })\n }\n }\n\n return originalValue\n }\n\n /**\n * Handles parameterization of object values.\n */\n #handleObject(obj: Record<string, unknown>, edge: InputEdge): unknown {\n if (hasFlag(edge, EdgeFlag.Object)) {\n const childNode = this.#view.inputNode(edge.childNodeId)\n if (childNode) {\n return this.#parameterizeObject(obj, childNode)\n }\n }\n\n const mask = getScalarMask(edge)\n if (mask & ScalarMask.Json) {\n const jsonValue = JSON.stringify(obj)\n const type: PlaceholderType = { type: 'Json' }\n return this.#getOrCreatePlaceholder(jsonValue, type)\n }\n\n return obj\n }\n\n /**\n * Parameterizes a selection set using output nodes.\n */\n #parameterizeSelection(selection: JsonSelectionSet, node: ReturnType<ParamGraph['outputNode']>): JsonSelectionSet {\n if (!selection || !node) {\n return selection\n }\n\n const result: JsonSelectionSet = {}\n\n for (const [key, value] of Object.entries(selection)) {\n if (key === '$scalars' || key === '$composites' || typeof value === 'boolean') {\n result[key] = value\n continue\n }\n\n const edge = this.#view.outputEdge(node, key)\n\n if (edge) {\n // Nested selection with possible args\n const nested = value as { arguments?: Record<string, unknown>; selection?: JsonSelectionSet }\n\n const argsNode = this.#view.inputNode(edge.argsNodeId)\n const childOutNode = this.#view.outputNode(edge.outputNodeId)\n\n const processedValue: JsonFieldSelection = {\n selection: nested.selection ? this.#parameterizeSelection(nested.selection, childOutNode) : {},\n }\n\n if (nested.arguments) {\n processedValue.arguments = this.#parameterizeObject(nested.arguments, argsNode)\n }\n\n result[key] = processedValue\n } else {\n result[key] = value\n }\n }\n\n return result\n }\n}\n\n/**\n * Creates a placeholder object with the given name.\n */\nfunction createPlaceholder(name: string, type: PlaceholderType): PlaceholderTaggedValue {\n return { $type: 'Param', value: { name, ...type } }\n}\n\n/**\n * Serializes a PlaceholderType to a string for use as part of a value key.\n */\nfunction serializePlaceholderType(type: PlaceholderType): string {\n if (type.type === 'List') {\n return `List<${serializePlaceholderType(type.inner)}>`\n }\n return type.type\n}\n\n/**\n * Serializes a value to a string for use as part of a value key.\n */\nfunction serializeValue(value: unknown): string {\n if (ArrayBuffer.isView(value)) {\n const bufView = Buffer.from(value.buffer, value.byteOffset, value.byteLength)\n return bufView.toString('base64')\n }\n return JSON.stringify(value)\n}\n\n/**\n * Creates a unique key for a (value, type) pair.\n * Used to detect when the same value appears multiple times.\n */\nfunction createValueKey(value: unknown, type: PlaceholderType): string {\n const typeKey = serializePlaceholderType(type)\n const valueKey = serializeValue(value)\n return `${typeKey}:${valueKey}`\n}\n\nconst MAX_INT = 2 ** 31 - 1\nconst MIN_INT = -(2 ** 31)\n\nfunction getPrimitivePlaceholderType(value: string | number | boolean): PlaceholderType {\n switch (typeof value) {\n case 'boolean':\n return { type: 'Boolean' }\n\n case 'number':\n if (!Number.isInteger(value)) {\n return { type: 'Float' }\n }\n if (MIN_INT <= value && value <= MAX_INT) {\n return { type: 'Int' }\n }\n return { type: 'BigInt' }\n\n case 'string':\n return { type: 'String' }\n\n default:\n throw new Error('unreachable')\n }\n}\n\n/**\n * Checks if a primitive value matches the scalar mask.\n */\nfunction matchesPrimitiveMask({ type }: PlaceholderType, mask: number): boolean {\n switch (type) {\n case 'Boolean':\n return (mask & ScalarMask.Boolean) !== 0\n case 'Int':\n return (mask & (ScalarMask.Int | ScalarMask.BigInt | ScalarMask.Float)) !== 0\n case 'BigInt':\n return (mask & ScalarMask.BigInt) !== 0\n case 'Float':\n return (mask & ScalarMask.Float) !== 0\n case 'String':\n return (mask & ScalarMask.String) !== 0\n default:\n return false\n }\n}\n\nfunction getTaggedPlaceholderType(tag: JsonInputTaggedValue['$type']): PlaceholderType | undefined {\n switch (tag) {\n case 'BigInt':\n case 'Bytes':\n case 'DateTime':\n case 'Json':\n return { type: tag }\n case 'Decimal':\n return { type: 'Float' }\n default:\n return undefined\n }\n}\n\n/**\n * Infers the placeholder type for an element in a list.\n * Used to determine the inner type of list placeholders.\n */\nfunction inferListElementType(item: unknown): PlaceholderType {\n const classified = classifyValue(item)\n\n switch (classified.kind) {\n case 'primitive':\n return getPrimitivePlaceholderType(classified.value)\n case 'taggedScalar': {\n const type = getTaggedPlaceholderType(classified.tag)\n return type ?? { type: 'Any' }\n }\n default:\n return { type: 'Any' }\n }\n}\n\n/**\n * Checks if a tagged scalar tag matches the scalar mask.\n */\nfunction matchesTaggedMask(tag: JsonInputTaggedValue['$type'], mask: number): boolean {\n switch (tag) {\n case 'DateTime':\n return (mask & ScalarMask.DateTime) !== 0\n case 'Decimal':\n return (mask & ScalarMask.Decimal) !== 0\n case 'BigInt':\n return (mask & ScalarMask.BigInt) !== 0\n case 'Bytes':\n return (mask & ScalarMask.Bytes) !== 0\n case 'Json':\n return (mask & ScalarMask.Json) !== 0\n default:\n return false\n }\n}\n\n/**\n * Validates that a list element can be parameterized.\n */\nfunction validateListElement(item: unknown, edge: InputEdge): boolean {\n const classified = classifyValue(item)\n\n switch (classified.kind) {\n case 'structural':\n return false\n\n case 'null':\n return false\n\n case 'primitive': {\n const type = getPrimitivePlaceholderType(classified.value)\n const mask = getScalarMask(edge)\n return mask !== 0 && matchesPrimitiveMask(type, mask)\n }\n\n case 'taggedScalar': {\n const mask = getScalarMask(edge)\n return mask !== 0 && matchesTaggedMask(classified.tag, mask)\n }\n\n default:\n return false\n }\n}\n\n/**\n * Decodes a value if it's a tagged scalar, otherwise returns as-is.\n */\nfunction decodeIfTagged(value: unknown): unknown {\n if (isTaggedValue(value)) {\n return decodeTaggedValue(value)\n }\n return value\n}\n\n/**\n * Decodes a tagged scalar value to its raw form.\n */\nfunction decodeTaggedValue(tagged: { $type: string; value: unknown }): unknown {\n return tagged.value\n}\n", "import type { BatchResponse, QueryPlanNode } from '@prisma/client-engine-runtime'\n\n// todo: store the query plan for the individual queries in a non-compacted batch\n// in the `#singleCache` so that it's possible to reuse them for compatible queries\n// outside of the batch in the future and avoid compiling them individually.\nexport class QueryPlanCache {\n readonly #singleCache: Map<string, QueryPlanNode>\n readonly #batchCache: Map<string, BatchResponse>\n readonly #maxSize: number\n\n constructor(maxSize = 1000) {\n this.#singleCache = new Map()\n this.#batchCache = new Map()\n this.#maxSize = maxSize\n }\n\n getSingle(key: string): QueryPlanNode | undefined {\n const entry = this.#singleCache.get(key)\n if (entry) {\n // Move to end for LRU behavior\n this.#singleCache.delete(key)\n this.#singleCache.set(key, entry)\n }\n return entry\n }\n\n setSingle(key: string, plan: QueryPlanNode): void {\n if (this.#singleCache.has(key)) {\n // Update existing entry (also moves to end for LRU)\n this.#singleCache.delete(key)\n this.#singleCache.set(key, plan)\n return\n }\n\n // Evict oldest if at capacity\n if (this.#singleCache.size >= this.#maxSize) {\n const firstKey = this.#singleCache.keys().next().value\n if (firstKey !== undefined) {\n this.#singleCache.delete(firstKey)\n }\n }\n\n this.#singleCache.set(key, plan)\n }\n\n getBatch(key: string): BatchResponse | undefined {\n const entry = this.#batchCache.get(key)\n if (entry) {\n // Move to end for LRU behavior\n this.#batchCache.delete(key)\n this.#batchCache.set(key, entry)\n }\n return entry\n }\n\n setBatch(key: string, response: BatchResponse): void {\n if (this.#batchCache.has(key)) {\n // Update existing entry (also moves to end for LRU)\n this.#batchCache.delete(key)\n this.#batchCache.set(key, response)\n return\n }\n\n // Evict oldest if at capacity\n if (this.#batchCache.size >= this.#maxSize) {\n const firstKey = this.#batchCache.keys().next().value\n if (firstKey !== undefined) {\n this.#batchCache.delete(firstKey)\n }\n }\n\n this.#batchCache.set(key, response)\n }\n\n clear(): void {\n this.#singleCache.clear()\n this.#batchCache.clear()\n }\n\n get size(): number {\n return this.#singleCache.size + this.#batchCache.size\n }\n\n get singleCacheSize(): number {\n return this.#singleCache.size\n }\n\n get batchCacheSize(): number {\n return this.#batchCache.size\n }\n}\n", "import type { QueryEngineLogLevel } from '@prisma/client-common'\nimport { applySqlCommenters, type TransactionOptions } from '@prisma/client-engine-runtime'\nimport { PrismaClientKnownRequestError } from '@prisma/client-runtime-utils'\nimport { Debug } from '@prisma/debug'\nimport type { EngineTraceEvent, TracingHelper } from '@prisma/instrumentation-contract'\nimport type { SqlCommenterPlugin } from '@prisma/sqlcommenter'\nimport { parseSetCookie, serialize as serializeCookie } from 'cookie-es'\n\nimport { getUrlAndApiKey } from '../accelerate/getUrlAndApiKey'\nimport { type AccelerateHeaders, HeaderBuilder } from '../accelerate/HeaderBuilder'\nimport type { AccelerateExtensionFetch } from '../common/Engine'\nimport type { LogEmitter } from '../common/types/Events'\nimport type { QueryEngineResultExtensions } from '../common/types/QueryEngine'\nimport type { InteractiveTransactionInfo } from '../common/types/Transaction'\nimport type { ExecutePlanParams, Executor, ProviderAndConnectionInfo } from './Executor'\nimport { dateFromEngineTimestamp } from './utils/engine-timestamp'\n\nconst debug = Debug('prisma:client:clientEngine:remoteExecutor')\n\nexport interface RemoteExecutorOptions {\n clientVersion: string\n logEmitter: LogEmitter\n logLevel: QueryEngineLogLevel\n logQueries: boolean\n tracingHelper: TracingHelper\n accelerateUrl: string\n sqlCommenters?: SqlCommenterPlugin[]\n}\n\nexport class RemoteExecutor implements Executor {\n readonly #clientVersion: string\n readonly #headerBuilder: HeaderBuilder\n readonly #httpClient: HttpClient\n readonly #logEmitter: LogEmitter\n readonly #tracingHelper: TracingHelper\n readonly #sqlCommenters?: SqlCommenterPlugin[]\n\n constructor(options: RemoteExecutorOptions) {\n this.#clientVersion = options.clientVersion\n this.#logEmitter = options.logEmitter\n this.#tracingHelper = options.tracingHelper\n this.#sqlCommenters = options.sqlCommenters\n\n const { url, apiKey } = getUrlAndApiKey({\n clientVersion: options.clientVersion,\n accelerateUrl: options.accelerateUrl,\n })\n\n this.#httpClient = new HttpClient(url)\n\n this.#headerBuilder = new HeaderBuilder({\n apiKey,\n engineHash: options.clientVersion,\n logLevel: options.logLevel,\n logQueries: options.logQueries,\n tracingHelper: options.tracingHelper,\n })\n }\n\n async getConnectionInfo(): Promise<ProviderAndConnectionInfo> {\n const connInfo = await this.#request({\n path: '/connection-info',\n method: 'GET',\n })\n return connInfo as ProviderAndConnectionInfo\n }\n\n async execute({\n plan,\n placeholderValues,\n batchIndex,\n model,\n operation,\n transaction,\n customFetch,\n queryInfo,\n }: ExecutePlanParams): Promise<unknown> {\n // Pre-compute comments from plugins\n const comments =\n queryInfo && this.#sqlCommenters?.length\n ? applySqlCommenters(this.#sqlCommenters, { query: queryInfo })\n : undefined\n\n const response = await this.#request({\n path: transaction ? `/transaction/${transaction.id}/query` : '/query',\n method: 'POST',\n body: {\n model,\n operation,\n plan,\n params: placeholderValues,\n // Send pre-computed comments to Query Plan Executor\n comments: comments && Object.keys(comments).length > 0 ? comments : undefined,\n },\n batchRequestIdx: batchIndex,\n fetch: customFetch,\n })\n\n return (response as Record<string, unknown>).data\n }\n\n async startTransaction(options: TransactionOptions): Promise<InteractiveTransactionInfo> {\n const txInfo = (await this.#request({\n path: '/transaction/start',\n method: 'POST',\n body: options,\n })) as { id: string }\n\n return { ...txInfo, payload: undefined }\n }\n\n async commitTransaction(transaction: InteractiveTransactionInfo): Promise<void> {\n await this.#request({\n path: `/transaction/${transaction.id}/commit`,\n method: 'POST',\n })\n }\n\n async rollbackTransaction(transaction: InteractiveTransactionInfo): Promise<void> {\n await this.#request({\n path: `/transaction/${transaction.id}/rollback`,\n method: 'POST',\n })\n }\n\n disconnect(): Promise<void> {\n return Promise.resolve()\n }\n\n apiKey(): string | null {\n return this.#headerBuilder.apiKey\n }\n\n async #request({\n path,\n method,\n body,\n fetch = globalThis.fetch,\n batchRequestIdx,\n }: {\n path: string\n method: string\n body?: unknown\n fetch?: AccelerateExtensionFetch\n batchRequestIdx?: number\n }): Promise<unknown> {\n const response = await this.#httpClient.request({\n method,\n path,\n headers: this.#headerBuilder.build(),\n body,\n fetch,\n })\n\n if (!response.ok) {\n await this.#throwErrorFromResponse(response, batchRequestIdx)\n }\n\n const responseJson = await response.json()\n\n if (typeof responseJson.extensions === 'object' && responseJson.extensions !== null) {\n this.#processExtensions(responseJson.extensions as QueryEngineResultExtensions)\n }\n\n return responseJson\n }\n\n async #throwErrorFromResponse(response: Response, batchRequestIdx?: number): Promise<never> {\n let errorCode = response.headers.get('Prisma-Error-Code')\n\n const responseText = await response.text()\n let errorJson: Record<string, unknown>\n let errorMessage = responseText\n\n try {\n errorJson = JSON.parse(responseText)\n } catch {\n errorJson = {}\n }\n\n if (typeof errorJson.code === 'string') {\n errorCode = errorJson.code\n }\n\n if (typeof errorJson.error === 'string') {\n // Query Plan Executor errors\n errorMessage = errorJson.error\n } else if (typeof errorJson.message === 'string') {\n // Accelerate errors\n errorMessage = errorJson.message\n } else if (\n // Certain specific Accelerate errors that mimic the shape of legacy Data Proxy errors\n // for backward compatibility with DataProxyEngine in the Client.\n typeof errorJson.InvalidRequestError === 'object' &&\n errorJson.InvalidRequestError !== null &&\n typeof (errorJson.InvalidRequestError as Record<string, unknown>).reason === 'string'\n ) {\n errorMessage = (errorJson.InvalidRequestError as Record<string, unknown>).reason as string\n }\n\n errorMessage = errorMessage || `HTTP ${response.status}: ${response.statusText}`\n\n const errorMeta =\n typeof errorJson.meta === 'object' && errorJson.meta !== null\n ? (errorJson.meta as Record<string, unknown>)\n : errorJson\n\n throw new PrismaClientKnownRequestError(errorMessage, {\n clientVersion: this.#clientVersion,\n code: errorCode ?? 'P6000',\n batchRequestIdx,\n meta: errorMeta,\n })\n }\n\n #processExtensions(extensions: QueryEngineResultExtensions): void {\n if (extensions.logs) {\n for (const log of extensions.logs) {\n this.#emitLogEvent(log)\n }\n }\n if (extensions.spans) {\n // FIXME: log events should be emitted in the context of the corresponding\n // spans to be consistent with the normal `ClientEngine` behavior. Our\n // current `TracingHelper` interface makes it challenging to do so.\n // We need to either change `dispatchEngineSpans` to be log-aware, or\n // not use `dispatchEngineSpans` here at all and emit the spans directly.\n // The second option is probably better long term so we can get rid of\n // `dispatchEngineSpans` entirely when QC is in GA and the QE is gone.\n this.#tracingHelper.dispatchEngineSpans(extensions.spans)\n }\n }\n\n #emitLogEvent(event: EngineTraceEvent): void {\n switch (event.level) {\n case 'debug':\n case 'trace':\n debug(event)\n break\n\n case 'error':\n case 'warn':\n case 'info': {\n this.#logEmitter.emit(event.level, {\n timestamp: dateFromEngineTimestamp(event.timestamp),\n message: event.attributes.message ?? '',\n target: event.target ?? 'RemoteExecutor',\n })\n break\n }\n\n case 'query': {\n this.#logEmitter.emit('query', {\n query: event.attributes.query ?? '',\n timestamp: dateFromEngineTimestamp(event.timestamp),\n duration: event.attributes.duration_ms ?? 0,\n params: event.attributes.params ?? '',\n target: event.target ?? 'RemoteExecutor',\n })\n\n break\n }\n\n default:\n throw new Error(`Unexpected log level: ${event.level satisfies never}`)\n }\n }\n}\n\n/**\n * HTTP client with support for cookies and machine hint headers.\n *\n * Accelerate uses cookies to route requests inside interactive transactions to\n * the correct instance.\n */\nclass HttpClient {\n readonly #baseUrl: URL\n readonly #cookieJar: Map<string, { name: string; value: string; domain: string; path: string; expires?: Date }>\n #machineHint: string | undefined\n\n constructor(baseUrl: URL) {\n this.#baseUrl = baseUrl\n this.#cookieJar = new Map()\n }\n\n async request({\n method,\n path,\n headers,\n body,\n fetch,\n }: {\n method: string\n path: string\n headers: AccelerateHeaders\n body: unknown\n fetch: AccelerateExtensionFetch\n }): Promise<Response> {\n const requestUrl = new URL(path, this.#baseUrl)\n\n const cookieHeader = this.#getCookieHeader(requestUrl)\n if (cookieHeader) {\n headers['Cookie'] = cookieHeader\n }\n\n if (this.#machineHint) {\n headers['Accelerate-Query-Engine-Jwt'] = this.#machineHint\n }\n\n const response = (await fetch(requestUrl.href, {\n method,\n body: body !== undefined ? JSON.stringify(body) : undefined,\n headers,\n })) as Response\n\n debug(method, requestUrl, response.status, response.statusText)\n\n this.#machineHint = response.headers.get('Accelerate-Query-Engine-Jwt') ?? undefined\n this.#storeCookiesFromResponse(requestUrl, response)\n\n return response\n }\n\n #getCookieHeader(url: URL): string | undefined {\n const validCookies: string[] = []\n const now = new Date()\n\n for (const [key, cookie] of this.#cookieJar) {\n if (cookie.expires && cookie.expires < now) {\n this.#cookieJar.delete(key)\n continue\n }\n\n const domain = cookie.domain ?? url.hostname\n const path = cookie.path ?? '/'\n\n if (url.hostname.endsWith(domain) && url.pathname.startsWith(path)) {\n validCookies.push(serializeCookie(cookie.name, cookie.value))\n }\n }\n\n return validCookies.length > 0 ? validCookies.join('; ') : undefined\n }\n\n #storeCookiesFromResponse(url: URL, response: Response): void {\n // Try to get Set-Cookie headers using the modern API first\n const setCookieHeaders = response.headers.getSetCookie?.() || []\n\n // Fallback to the traditional method if getSetCookie is not available\n if (setCookieHeaders.length === 0) {\n const setCookieHeader = response.headers.get('Set-Cookie')\n if (setCookieHeader) {\n setCookieHeaders.push(setCookieHeader)\n }\n }\n\n for (const cookieString of setCookieHeaders) {\n const cookie = parseSetCookie(cookieString)\n\n const domain = cookie.domain ?? url.hostname\n const path = cookie.path ?? '/'\n const key = `${domain}:${path}:${cookie.name}`\n\n this.#cookieJar.set(key, {\n name: cookie.name,\n value: cookie.value,\n domain,\n path,\n expires: cookie.expires,\n })\n }\n }\n}\n", "function parse(str, options) {\n if (typeof str !== \"string\") {\n throw new TypeError(\"argument str must be a string\");\n }\n const obj = {};\n const opt = options || {};\n const dec = opt.decode || decode;\n let index = 0;\n while (index < str.length) {\n const eqIdx = str.indexOf(\"=\", index);\n if (eqIdx === -1) {\n break;\n }\n let endIdx = str.indexOf(\";\", index);\n if (endIdx === -1) {\n endIdx = str.length;\n } else if (endIdx < eqIdx) {\n index = str.lastIndexOf(\";\", eqIdx - 1) + 1;\n continue;\n }\n const key = str.slice(index, eqIdx).trim();\n if (opt?.filter && !opt?.filter(key)) {\n index = endIdx + 1;\n continue;\n }\n if (void 0 === obj[key]) {\n let val = str.slice(eqIdx + 1, endIdx).trim();\n if (val.codePointAt(0) === 34) {\n val = val.slice(1, -1);\n }\n obj[key] = tryDecode(val, dec);\n }\n index = endIdx + 1;\n }\n return obj;\n}\nfunction decode(str) {\n return str.includes(\"%\") ? decodeURIComponent(str) : str;\n}\nfunction tryDecode(str, decode2) {\n try {\n return decode2(str);\n } catch {\n return str;\n }\n}\n\nconst fieldContentRegExp = /^[\\u0009\\u0020-\\u007E\\u0080-\\u00FF]+$/;\nfunction serialize(name, value, options) {\n const opt = options || {};\n const enc = opt.encode || encodeURIComponent;\n if (typeof enc !== \"function\") {\n throw new TypeError(\"option encode is invalid\");\n }\n if (!fieldContentRegExp.test(name)) {\n throw new TypeError(\"argument name is invalid\");\n }\n const encodedValue = enc(value);\n if (encodedValue && !fieldContentRegExp.test(encodedValue)) {\n throw new TypeError(\"argument val is invalid\");\n }\n let str = name + \"=\" + encodedValue;\n if (void 0 !== opt.maxAge && opt.maxAge !== null) {\n const maxAge = opt.maxAge - 0;\n if (Number.isNaN(maxAge) || !Number.isFinite(maxAge)) {\n throw new TypeError(\"option maxAge is invalid\");\n }\n str += \"; Max-Age=\" + Math.floor(maxAge);\n }\n if (opt.domain) {\n if (!fieldContentRegExp.test(opt.domain)) {\n throw new TypeError(\"option domain is invalid\");\n }\n str += \"; Domain=\" + opt.domain;\n }\n if (opt.path) {\n if (!fieldContentRegExp.test(opt.path)) {\n throw new TypeError(\"option path is invalid\");\n }\n str += \"; Path=\" + opt.path;\n }\n if (opt.expires) {\n if (!isDate(opt.expires) || Number.isNaN(opt.expires.valueOf())) {\n throw new TypeError(\"option expires is invalid\");\n }\n str += \"; Expires=\" + opt.expires.toUTCString();\n }\n if (opt.httpOnly) {\n str += \"; HttpOnly\";\n }\n if (opt.secure) {\n str += \"; Secure\";\n }\n if (opt.priority) {\n const priority = typeof opt.priority === \"string\" ? opt.priority.toLowerCase() : opt.priority;\n switch (priority) {\n case \"low\": {\n str += \"; Priority=Low\";\n break;\n }\n case \"medium\": {\n str += \"; Priority=Medium\";\n break;\n }\n case \"high\": {\n str += \"; Priority=High\";\n break;\n }\n default: {\n throw new TypeError(\"option priority is invalid\");\n }\n }\n }\n if (opt.sameSite) {\n const sameSite = typeof opt.sameSite === \"string\" ? opt.sameSite.toLowerCase() : opt.sameSite;\n switch (sameSite) {\n case true: {\n str += \"; SameSite=Strict\";\n break;\n }\n case \"lax\": {\n str += \"; SameSite=Lax\";\n break;\n }\n case \"strict\": {\n str += \"; SameSite=Strict\";\n break;\n }\n case \"none\": {\n str += \"; SameSite=None\";\n break;\n }\n default: {\n throw new TypeError(\"option sameSite is invalid\");\n }\n }\n }\n if (opt.partitioned) {\n str += \"; Partitioned\";\n }\n return str;\n}\nfunction isDate(val) {\n return Object.prototype.toString.call(val) === \"[object Date]\" || val instanceof Date;\n}\n\nfunction parseSetCookie(setCookieValue, options) {\n const parts = (setCookieValue || \"\").split(\";\").filter((str) => typeof str === \"string\" && !!str.trim());\n const nameValuePairStr = parts.shift() || \"\";\n const parsed = _parseNameValuePair(nameValuePairStr);\n const name = parsed.name;\n let value = parsed.value;\n try {\n value = options?.decode === false ? value : (options?.decode || decodeURIComponent)(value);\n } catch {\n }\n const cookie = {\n name,\n value\n };\n for (const part of parts) {\n const sides = part.split(\"=\");\n const partKey = (sides.shift() || \"\").trimStart().toLowerCase();\n const partValue = sides.join(\"=\");\n switch (partKey) {\n case \"expires\": {\n cookie.expires = new Date(partValue);\n break;\n }\n case \"max-age\": {\n cookie.maxAge = Number.parseInt(partValue, 10);\n break;\n }\n case \"secure\": {\n cookie.secure = true;\n break;\n }\n case \"httponly\": {\n cookie.httpOnly = true;\n break;\n }\n case \"samesite\": {\n cookie.sameSite = partValue;\n break;\n }\n default: {\n cookie[partKey] = partValue;\n }\n }\n }\n return cookie;\n}\nfunction _parseNameValuePair(nameValuePairStr) {\n let name = \"\";\n let value = \"\";\n const nameValueArr = nameValuePairStr.split(\"=\");\n if (nameValueArr.length > 1) {\n name = nameValueArr.shift();\n value = nameValueArr.join(\"=\");\n } else {\n value = nameValuePairStr;\n }\n return { name, value };\n}\n\nfunction splitSetCookieString(cookiesString) {\n if (Array.isArray(cookiesString)) {\n return cookiesString.flatMap((c) => splitSetCookieString(c));\n }\n if (typeof cookiesString !== \"string\") {\n return [];\n }\n const cookiesStrings = [];\n let pos = 0;\n let start;\n let ch;\n let lastComma;\n let nextStart;\n let cookiesSeparatorFound;\n const skipWhitespace = () => {\n while (pos < cookiesString.length && /\\s/.test(cookiesString.charAt(pos))) {\n pos += 1;\n }\n return pos < cookiesString.length;\n };\n const notSpecialChar = () => {\n ch = cookiesString.charAt(pos);\n return ch !== \"=\" && ch !== \";\" && ch !== \",\";\n };\n while (pos < cookiesString.length) {\n start = pos;\n cookiesSeparatorFound = false;\n while (skipWhitespace()) {\n ch = cookiesString.charAt(pos);\n if (ch === \",\") {\n lastComma = pos;\n pos += 1;\n skipWhitespace();\n nextStart = pos;\n while (pos < cookiesString.length && notSpecialChar()) {\n pos += 1;\n }\n if (pos < cookiesString.length && cookiesString.charAt(pos) === \"=\") {\n cookiesSeparatorFound = true;\n pos = nextStart;\n cookiesStrings.push(cookiesString.slice(start, lastComma));\n start = pos;\n } else {\n pos = lastComma + 1;\n }\n } else {\n pos += 1;\n }\n }\n if (!cookiesSeparatorFound || pos >= cookiesString.length) {\n cookiesStrings.push(cookiesString.slice(start));\n }\n }\n return cookiesStrings;\n}\n\nexport { parse, parseSetCookie, serialize, splitSetCookieString };\n", "export interface PrismaClientErrorInfo {\n clientVersion: string\n cause?: Error\n}\n\nexport abstract class PrismaClientError extends Error {\n public abstract name: string\n public abstract code: string\n public clientVersion: string\n public cause?: Error // like https://github.com/es-shims/error-cause\n\n constructor(message: string, info: PrismaClientErrorInfo) {\n super(message)\n\n this.clientVersion = info.clientVersion\n this.cause = info.cause\n }\n\n get [Symbol.toStringTag]() {\n return this.name\n }\n}\n", "import { PrismaClientError, type PrismaClientErrorInfo } from '../../../errors/PrismaClientError'\n\nexport interface AccelerateErrorInfo extends PrismaClientErrorInfo {\n isRetryable?: boolean\n}\n\nexport abstract class AccelerateError extends PrismaClientError {\n isRetryable: boolean\n\n constructor(message: string, info: AccelerateErrorInfo) {\n super(message, info)\n\n this.isRetryable = info.isRetryable ?? true\n }\n}\n", "export function setRetryable<T>(info: T, retryable: boolean) {\n return {\n ...info,\n isRetryable: retryable,\n }\n}\n", "import { setClassName } from '@prisma/internals'\n\nimport type { AccelerateErrorInfo } from './accelerate-error'\nimport { AccelerateError } from './accelerate-error'\nimport { setRetryable } from './utils/set-retryable'\n\nexport interface InvalidDatasourceErrorInfo extends AccelerateErrorInfo {}\nexport class InvalidDatasourceError extends AccelerateError {\n public name = 'InvalidDatasourceError'\n public code = 'P6001'\n\n constructor(message: string, info: InvalidDatasourceErrorInfo) {\n super(message, setRetryable(info, false))\n }\n}\nsetClassName(InvalidDatasourceError, 'InvalidDatasourceError')\n", "import { isPrismaPostgresDev, PRISMA_POSTGRES_PROTOCOL } from '@prisma/internals'\n\nimport { InvalidDatasourceError } from './errors/invalid-datasource-error'\n\nexport interface GetUrlAndApiKeyOptions {\n clientVersion: string\n accelerateUrl: string\n}\n\nexport interface UrlAndApiKey {\n url: HttpUrl\n apiKey: string\n}\n\nexport type HttpUrl = URL & { protocol: 'http' | 'https' }\n\nexport function getUrlAndApiKey(options: GetUrlAndApiKeyOptions): UrlAndApiKey {\n const errorInfo = { clientVersion: options.clientVersion }\n\n let url: URL\n try {\n url = new URL(options.accelerateUrl)\n } catch (err) {\n const message = (err as TypeError).message\n throw new InvalidDatasourceError(\n `Error validating \\`accelerateUrl\\`, the URL cannot be parsed, reason: ${message}`,\n errorInfo,\n )\n }\n\n const { protocol, searchParams } = url\n\n if (protocol !== 'prisma:' && protocol !== PRISMA_POSTGRES_PROTOCOL) {\n throw new InvalidDatasourceError(\n `Error validating \\`accelerateUrl\\`: the URL must start with the protocol \\`prisma://\\` or \\`prisma+postgres://\\``,\n errorInfo,\n )\n }\n\n const apiKey = searchParams.get('api_key')\n if (apiKey === null || apiKey.length < 1) {\n throw new InvalidDatasourceError(\n `Error validating \\`accelerateUrl\\`: the URL must contain a valid API key`,\n errorInfo,\n )\n }\n\n // To simplify things, `prisma dev`, for now, will not support HTTPS.\n // In the future, if HTTPS for `prisma dev` becomes a thing, we'll need this line to be dynamic.\n let httpScheme = isPrismaPostgresDev(url) ? 'http:' : 'https:'\n\n if (process.env.TEST_CLIENT_ENGINE_REMOTE_EXECUTOR && url.searchParams.has('use_http')) {\n httpScheme = 'http:'\n }\n\n // Switching from `prisma:` or `prisma+postgres:` to `http:` or `https:` by\n // assigning to the `protocol` property is not allowed by the WHATWG URL API,\n // it would be silently ignored without throwing an error. We have to manually\n // update the protocol via string replacement.\n const httpUrl = new URL(url.href.replace(protocol, httpScheme)) as HttpUrl\n\n return { apiKey, url: httpUrl }\n}\n", "import type { QueryEngineLogLevel } from '@prisma/client-common'\nimport { enginesVersion } from '@prisma/engines-version'\nimport type { TracingHelper } from '@prisma/instrumentation-contract'\n\nexport type AccelerateHeaders = {\n 'Content-Type': string\n 'Prisma-Engine-Hash': string\n 'Prisma-Engine-Version': string\n 'X-Capture-Telemetry'?: string\n 'X-Transaction-Id'?: string\n Accept: string\n Authorization: string\n traceparent?: string\n}\n\ntype HeaderBuilderOptions = {\n traceparent?: string\n transactionId?: string\n}\n\nexport class HeaderBuilder {\n readonly apiKey: string\n readonly tracingHelper: TracingHelper\n readonly logLevel: QueryEngineLogLevel\n readonly logQueries: boolean | undefined\n readonly engineHash: string\n\n constructor({\n apiKey,\n tracingHelper,\n logLevel,\n logQueries,\n engineHash,\n }: {\n apiKey: string\n tracingHelper: TracingHelper\n logLevel: QueryEngineLogLevel\n logQueries: boolean | undefined\n engineHash: string\n }) {\n this.apiKey = apiKey\n this.tracingHelper = tracingHelper\n this.logLevel = logLevel\n this.logQueries = logQueries\n this.engineHash = engineHash\n }\n\n build({ traceparent, transactionId }: HeaderBuilderOptions = {}): AccelerateHeaders {\n const headers: AccelerateHeaders = {\n Accept: 'application/json',\n Authorization: `Bearer ${this.apiKey}`,\n 'Content-Type': 'application/json',\n 'Prisma-Engine-Hash': this.engineHash,\n 'Prisma-Engine-Version': enginesVersion,\n }\n\n if (this.tracingHelper.isEnabled()) {\n headers.traceparent = traceparent ?? this.tracingHelper.getTraceParent()\n }\n\n if (transactionId) {\n headers['X-Transaction-Id'] = transactionId\n }\n\n const captureTelemetry = this.#buildCaptureSettings()\n\n if (captureTelemetry.length > 0) {\n headers['X-Capture-Telemetry'] = captureTelemetry.join(', ')\n }\n\n return headers\n }\n\n #buildCaptureSettings(): string[] {\n const captureTelemetry: string[] = []\n\n if (this.tracingHelper.isEnabled()) {\n captureTelemetry.push('tracing')\n }\n\n if (this.logLevel) {\n captureTelemetry.push(this.logLevel)\n }\n\n if (this.logQueries) {\n captureTelemetry.push('query')\n }\n\n return captureTelemetry\n }\n}\n", "export type EngineTimestamp = [seconds: number, nanoseconds: number]\n\n/**\n * Converts engine timestamp to JS timestamp, as accepted by `Date` constructor\n */\nexport function convertEngineTimestamp(timestamp: EngineTimestamp): number {\n return timestamp[0] * 1e3 + timestamp[1] / 1e6\n}\n\n/**\n * Parses a `Date` from engine timestamp\n */\nexport function dateFromEngineTimestamp(timestamp: EngineTimestamp): Date {\n return new Date(convertEngineTimestamp(timestamp))\n}\n", "import { QueryCompilerConstructor } from '@prisma/client-common'\nimport { PrismaClientInitializationError } from '@prisma/client-runtime-utils'\n\nimport { QueryCompilerLoader } from './types/QueryCompiler'\n\n// cache loaded wasm instances by provider\nconst loadedWasmInstances: Record<string, Promise<QueryCompilerConstructor>> = {}\n\nexport const wasmQueryCompilerLoader: QueryCompilerLoader = {\n async loadQueryCompiler(config) {\n const { clientVersion, compilerWasm } = config\n\n if (compilerWasm === undefined) {\n throw new PrismaClientInitializationError('WASM query compiler was unexpectedly `undefined`', clientVersion)\n }\n\n let loading: Promise<QueryCompilerConstructor>\n\n // we only create the instance once for efficiency and also because wasm\n // bindgen keeps an internal cache of its instance already, when the wasm\n // compiler is loaded more than once it crashes with `unwrap_throw failed`.\n if (config.activeProvider === undefined || loadedWasmInstances[config.activeProvider] === undefined) {\n loading = (async () => {\n const runtime = await compilerWasm.getRuntime()\n const wasmModule = await compilerWasm.getQueryCompilerWasmModule()\n\n if (wasmModule === undefined || wasmModule === null) {\n throw new PrismaClientInitializationError(\n 'The loaded wasm module was unexpectedly `undefined` or `null` once loaded',\n clientVersion,\n )\n }\n\n // from https://developers.cloudflare.com/workers/runtime-apis/webassembly/rust/#javascript-plumbing-wasm-bindgen\n const options = { [compilerWasm.importName]: runtime }\n const instance = new WebAssembly.Instance(wasmModule, options)\n const wbindgen_start = instance.exports.__wbindgen_start as () => void\n runtime.__wbg_set_wasm(instance.exports)\n wbindgen_start()\n return runtime.QueryCompiler\n })()\n\n // only cache if we have an active provider\n if (config.activeProvider !== undefined) {\n loadedWasmInstances[config.activeProvider] = loading\n }\n } else {\n loading = loadedWasmInstances[config.activeProvider]\n }\n\n return await loading\n },\n}\n", "import { ClientEngine, Engine, EngineConfig } from '../engines'\n\n/**\n * Get the engine instance based on the runtime bundle type and engine configuration.\n */\nexport function getEngineInstance(engineConfig: EngineConfig): Engine {\n return new ClientEngine(engineConfig)\n}\n", "export const rawCommandArgsMapper = (command: object) => ({\n command,\n})\n", "import { Sql } from '@prisma/client-runtime-utils'\nimport { Debug } from '@prisma/debug'\n\nimport { MiddlewareArgsMapper } from '../../getPrismaClient'\nimport { mssqlPreparedStatement } from '../../utils/mssqlPreparedStatement'\nimport { serializeRawParameters } from '../../utils/serializeRawParameters'\nimport { isTypedSql } from '../types/exported'\nimport { RawQueryArgs } from '../types/exported/RawQueryArgs'\n\nconst ALTER_RE = /^(\\s*alter\\s)/i\n\nconst debug = Debug('prisma:client')\n\n// TODO also check/disallow for CREATE, DROP\nexport function checkAlter(activeProvider: string, query: string, values: unknown[], invalidCall: string) {\n if (activeProvider !== 'postgresql' && activeProvider !== 'cockroachdb') {\n return\n }\n if (values.length > 0 && ALTER_RE.exec(query)) {\n // See https://github.com/prisma/prisma-client-js/issues/940 for more info\n throw new Error(`Running ALTER using ${invalidCall} is not supported\nUsing the example below you can still execute your query with Prisma, but please note that it is vulnerable to SQL injection attacks and requires you to take care of input sanitization.\n\nExample:\n await prisma.$executeRawUnsafe(\\`ALTER USER prisma WITH PASSWORD '\\${password}'\\`)\n\nMore Information: https://pris.ly/d/execute-raw\n`)\n }\n}\n\ntype RawQueryArgsMapperInput = {\n clientMethod: string\n activeProvider: string\n}\n\nexport const rawQueryArgsMapper =\n ({ clientMethod, activeProvider }: RawQueryArgsMapperInput) =>\n (args: RawQueryArgs) => {\n // TODO Clean up types\n let queryString = ''\n let parameters: { values: string; __prismaRawParameters__: true } | undefined\n if (isTypedSql(args)) {\n queryString = args.sql\n parameters = {\n values: serializeRawParameters(args.values),\n __prismaRawParameters__: true,\n }\n } else if (Array.isArray(args)) {\n // If this was called as prisma.$executeRaw(<SQL>, [...values]), assume it is a pre-prepared SQL statement, and forward it without any changes\n const [query, ...values] = args\n queryString = query\n parameters = {\n values: serializeRawParameters(values || []),\n __prismaRawParameters__: true,\n }\n } else {\n // If this was called as prisma.$executeRaw`<SQL>` try to generate a SQL prepared statement\n switch (activeProvider) {\n case 'sqlite':\n case 'mysql': {\n queryString = args.sql\n parameters = {\n values: serializeRawParameters(args.values),\n __prismaRawParameters__: true,\n }\n break\n }\n\n case 'cockroachdb':\n case 'postgresql':\n case 'postgres': {\n queryString = args.text\n\n parameters = {\n values: serializeRawParameters(args.values),\n __prismaRawParameters__: true,\n }\n break\n }\n\n case 'sqlserver': {\n queryString = mssqlPreparedStatement(args)\n parameters = {\n values: serializeRawParameters(args.values),\n __prismaRawParameters__: true,\n }\n break\n }\n default: {\n throw new Error(`The ${activeProvider} provider does not support ${clientMethod}`)\n }\n }\n }\n\n if (parameters?.values) {\n debug(`prisma.${clientMethod}(${queryString}, ${parameters.values})`)\n } else {\n debug(`prisma.${clientMethod}(${queryString})`)\n }\n\n return { query: queryString, parameters }\n }\n\ntype MiddlewareRawArgsTemplateString = [string[], ...unknown[]]\ntype MiddlewareRawArgsSql = [Sql]\n\nexport const templateStringMiddlewareArgsMapper: MiddlewareArgsMapper<Sql, MiddlewareRawArgsTemplateString> = {\n requestArgsToMiddlewareArgs(sql) {\n return [sql.strings, ...sql.values]\n },\n\n middlewareArgsToRequestArgs(requestArgs) {\n const [strings, ...values] = requestArgs\n return new Sql(strings, values)\n },\n}\n\nexport const sqlMiddlewareArgsMapper: MiddlewareArgsMapper<Sql, MiddlewareRawArgsSql> = {\n requestArgsToMiddlewareArgs(sql) {\n return [sql]\n },\n\n middlewareArgsToRequestArgs(requestArgs) {\n return requestArgs[0]\n },\n}\n", "import type { Sql } from '@prisma/client-runtime-utils'\n\n// Generate something like: SELECT * FROM User WHERE name = @P1 AND email = @P2 ...\nexport const mssqlPreparedStatement = (sql: Sql) => {\n return sql.strings.reduce((acc, str, idx) => `${acc}@P${idx}${str}`)\n}\n", "import { Decimal } from '@prisma/client-runtime-utils'\n\nimport { isDate } from './date'\n\nexport function serializeRawParameters(parameters: any[]): string {\n try {\n return serializeRawParametersInternal(parameters, 'fast')\n } catch (error) {\n // Got TypeError, try replacing values unsupported by JSON (i.e., BigInts)\n // with strings inside arrays and objects.\n return serializeRawParametersInternal(parameters, 'slow')\n }\n}\n\nfunction serializeRawParametersInternal(parameters: any[], objectSerialization: 'fast' | 'slow'): string {\n return JSON.stringify(parameters.map((parameter) => encodeParameter(parameter, objectSerialization)))\n}\n\nfunction encodeParameter(parameter: any, objectSerialization: 'fast' | 'slow'): unknown {\n if (Array.isArray(parameter)) {\n return parameter.map((item) => encodeParameter(item, objectSerialization))\n }\n if (typeof parameter === 'bigint') {\n return {\n prisma__type: 'bigint',\n prisma__value: parameter.toString(),\n }\n }\n\n if (isDate(parameter)) {\n return {\n prisma__type: 'date',\n prisma__value: parameter.toJSON(),\n }\n }\n\n if (Decimal.isDecimal(parameter)) {\n return {\n prisma__type: 'decimal',\n prisma__value: parameter.toJSON(),\n }\n }\n\n if (Buffer.isBuffer(parameter)) {\n return {\n prisma__type: 'bytes',\n prisma__value: parameter.toString('base64'),\n }\n }\n\n if (isArrayBufferLike(parameter)) {\n return {\n prisma__type: 'bytes',\n prisma__value: Buffer.from(parameter).toString('base64'),\n }\n }\n\n if (ArrayBuffer.isView(parameter)) {\n const { buffer, byteOffset, byteLength } = parameter\n return {\n prisma__type: 'bytes',\n prisma__value: Buffer.from(buffer, byteOffset, byteLength).toString('base64'),\n }\n }\n\n if (typeof parameter === 'object' && objectSerialization === 'slow') {\n return preprocessObject(parameter)\n }\n\n return parameter\n}\n\nfunction isArrayBufferLike(value: any): value is ArrayBufferLike {\n if (value instanceof ArrayBuffer || value instanceof SharedArrayBuffer) {\n return true\n }\n\n if (typeof value === 'object' && value !== null) {\n return value[Symbol.toStringTag] === 'ArrayBuffer' || value[Symbol.toStringTag] === 'SharedArrayBuffer'\n }\n\n return false\n}\n\nfunction preprocessObject(obj: any): unknown {\n if (typeof obj !== 'object' || obj === null) {\n return obj\n }\n\n if (typeof obj.toJSON === 'function') {\n return obj.toJSON()\n }\n\n // TODO: map from blaze would've been convenient here to map arrays and objects uniformly,\n // but importing it in this file causes compilation errors in tsd tests.\n\n if (Array.isArray(obj)) {\n return obj.map(preprocessValueInObject)\n }\n\n const result = {} as any\n\n for (const key of Object.keys(obj as object)) {\n result[key] = preprocessValueInObject(obj[key])\n }\n\n return result\n}\n\nfunction preprocessValueInObject(value: any): unknown {\n if (typeof value === 'bigint') {\n return value.toString()\n }\n\n return preprocessObject(value)\n}\n", "import type { PrismaOperationSpec, PrismaPromise, PrismaPromiseTransaction } from './PrismaPromise'\n\nexport type PrismaPromiseCallback = (transaction?: PrismaPromiseTransaction) => Promise<unknown>\n\n/**\n * Creates a [[PrismaPromise]]. It is Prisma's implementation of `Promise` which\n * is essentially a proxy for `Promise`. All the transaction-compatible client\n * methods return one, this allows for pre-preparing queries without executing\n * them until `.then` is called. It's the foundation of Prisma's query batching.\n * @param callback that will be wrapped within our promise implementation\n * @see [[PrismaPromise]]\n * @returns\n */\nexport type PrismaPromiseFactory = <T extends PrismaOperationSpec<unknown>>(\n callback: PrismaPromiseCallback,\n op?: T,\n) => PrismaPromise<unknown>\n\n/**\n * Creates a factory, that allows creating PrismaPromises, bound to a specific transactions\n * @param transaction\n * @returns\n */\nexport function createPrismaPromiseFactory(transaction?: PrismaPromiseTransaction): PrismaPromiseFactory {\n return function createPrismaPromise<TSpec extends PrismaOperationSpec<unknown>>(\n callback: PrismaPromiseCallback,\n op?: TSpec,\n ): PrismaPromise<unknown, TSpec> {\n let promise: PrismaPromise<unknown> | undefined\n const _callback = (callbackTransaction = transaction): PrismaPromise<unknown> => {\n try {\n // promises cannot be triggered twice after resolving\n if (callbackTransaction === undefined || callbackTransaction?.kind === 'itx') {\n return (promise ??= valueToPromise(callback(callbackTransaction)))\n }\n\n // but for batch tx we can trigger them again & again\n return valueToPromise(callback(callbackTransaction))\n } catch (error) {\n // if the callback throws, then we reject the promise\n // and that is because exceptions are not always async\n return Promise.reject(error) as PrismaPromise<unknown>\n }\n }\n\n return {\n get spec() {\n return op!\n },\n\n then(onFulfilled, onRejected) {\n return _callback().then(onFulfilled, onRejected)\n },\n catch(onRejected) {\n return _callback().catch(onRejected)\n },\n finally(onFinally) {\n return _callback().finally(onFinally)\n },\n\n requestTransaction(batchTransaction) {\n const promise = _callback(batchTransaction)\n\n if (promise.requestTransaction) {\n // we want to have support for nested promises\n return promise.requestTransaction(batchTransaction)\n }\n\n return promise\n },\n [Symbol.toStringTag]: 'PrismaPromise',\n }\n }\n}\n\nfunction valueToPromise<T>(thing: T): PrismaPromise<T> {\n if (typeof thing['then'] === 'function') {\n return thing as PrismaPromise<T>\n }\n\n return Promise.resolve(thing) as PrismaPromise<T>\n}\n", "{\n \"name\": \"@prisma/instrumentation-contract\",\n \"version\": \"7.4.0-integration-parameterization.21\",\n \"description\": \"Shared types and utilities for Prisma instrumentation\",\n \"main\": \"dist/index.js\",\n \"module\": \"dist/index.mjs\",\n \"types\": \"dist/index.d.ts\",\n \"exports\": {\n \".\": {\n \"require\": {\n \"types\": \"./dist/index.d.ts\",\n \"default\": \"./dist/index.js\"\n },\n \"import\": {\n \"types\": \"./dist/index.d.mts\",\n \"default\": \"./dist/index.mjs\"\n }\n }\n },\n \"license\": \"Apache-2.0\",\n \"homepage\": \"https://www.prisma.io\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/prisma/prisma.git\",\n \"directory\": \"packages/instrumentation-contract\"\n },\n \"bugs\": \"https://github.com/prisma/prisma/issues\",\n \"scripts\": {\n \"dev\": \"DEV=true tsx helpers/build.ts\",\n \"build\": \"tsx helpers/build.ts\",\n \"prepublishOnly\": \"pnpm run build\",\n \"test\": \"vitest run\"\n },\n \"files\": [\n \"dist\"\n ],\n \"sideEffects\": false,\n \"devDependencies\": {\n \"@opentelemetry/api\": \"1.9.0\"\n },\n \"peerDependencies\": {\n \"@opentelemetry/api\": \"^1.8\"\n }\n}", "import packageJson from '../package.json'\nimport type { PrismaInstrumentationGlobalValue, TracingHelper } from './types'\n\nconst majorVersion = packageJson.version.split('.')[0]\n\nconst GLOBAL_INSTRUMENTATION_KEY = 'PRISMA_INSTRUMENTATION'\nconst GLOBAL_VERSIONED_INSTRUMENTATION_KEY = `V${majorVersion}_PRISMA_INSTRUMENTATION` as const\n\ntype GlobalThisWithPrismaInstrumentation = typeof globalThis & {\n [GLOBAL_INSTRUMENTATION_KEY]?: PrismaInstrumentationGlobalValue\n} & {\n [K in typeof GLOBAL_VERSIONED_INSTRUMENTATION_KEY]?: PrismaInstrumentationGlobalValue\n}\n\nconst globalThisWithPrismaInstrumentation = globalThis as GlobalThisWithPrismaInstrumentation\n\n/**\n * Returns the TracingHelper from the global instrumentation if available,\n * preferring the versioned global over the fallback global for compatibility.\n */\nexport function getGlobalTracingHelper(): TracingHelper | undefined {\n // Try versioned global first for major version isolation\n const versionedGlobal = globalThisWithPrismaInstrumentation[GLOBAL_VERSIONED_INSTRUMENTATION_KEY]\n\n if (versionedGlobal?.helper) {\n return versionedGlobal.helper\n }\n\n // Fall back to unversioned global for backwards compatibility\n // TODO(v8): Consider removing the fallback in future major versions\n const fallbackGlobal = globalThisWithPrismaInstrumentation[GLOBAL_INSTRUMENTATION_KEY]\n\n return fallbackGlobal?.helper\n}\n\n/**\n * Sets the global tracing helper. This is called by @prisma/instrumentation\n * when instrumentation is enabled.\n */\nexport function setGlobalTracingHelper(helper: TracingHelper): void {\n const globalValue: PrismaInstrumentationGlobalValue = { helper }\n\n // Set both versioned and unversioned globals for compatibility\n // TODO(v8): Consider only writing to the versioned global in future major versions\n globalThisWithPrismaInstrumentation[GLOBAL_VERSIONED_INSTRUMENTATION_KEY] = globalValue\n globalThisWithPrismaInstrumentation[GLOBAL_INSTRUMENTATION_KEY] = globalValue\n}\n\n/**\n * Clears the global tracing helper. This is called by @prisma/instrumentation\n * when instrumentation is disabled.\n */\nexport function clearGlobalTracingHelper(): void {\n delete globalThisWithPrismaInstrumentation[GLOBAL_VERSIONED_INSTRUMENTATION_KEY]\n delete globalThisWithPrismaInstrumentation[GLOBAL_INSTRUMENTATION_KEY]\n}\n", "import type { Context } from '@opentelemetry/api'\nimport {\n EngineSpan,\n ExtendedSpanOptions,\n getGlobalTracingHelper,\n SpanCallback,\n TracingHelper,\n} from '@prisma/instrumentation-contract'\n\nexport const disabledTracingHelper: TracingHelper = {\n isEnabled() {\n return false\n },\n getTraceParent() {\n // https://www.w3.org/TR/trace-context/#examples-of-http-traceparent-headers\n // If traceparent ends with -00 this trace will not be sampled\n // the query engine needs the `10` for the span and trace id otherwise it does not parse this\n return `00-10-10-00`\n },\n\n dispatchEngineSpans() {},\n\n getActiveContext() {\n return undefined\n },\n\n runInChildSpan<R>(options: string | ExtendedSpanOptions, callback: SpanCallback<R>): R {\n return callback()\n },\n}\n\n/**\n * Tracing helper that can dynamically switch between enabled/disabled states\n * Needed because tracing can be disabled and enabled with the calls to\n * PrismaInstrumentation::disable/enable at any point\n */\nclass DynamicTracingHelper implements TracingHelper {\n isEnabled(): boolean {\n return this.getTracingHelper().isEnabled()\n }\n getTraceParent(context: Context) {\n return this.getTracingHelper().getTraceParent(context)\n }\n\n dispatchEngineSpans(spans: EngineSpan[]) {\n return this.getTracingHelper().dispatchEngineSpans(spans)\n }\n\n getActiveContext() {\n return this.getTracingHelper().getActiveContext()\n }\n runInChildSpan<R>(options: string | ExtendedSpanOptions, callback: SpanCallback<R>): R {\n return this.getTracingHelper().runInChildSpan(options, callback)\n }\n\n private getTracingHelper(): TracingHelper {\n return getGlobalTracingHelper() ?? disabledTracingHelper\n }\n}\n\nexport function getTracingHelper(): TracingHelper {\n return new DynamicTracingHelper()\n}\n", "/**\n * Creates an exotic promise that opens after x `await`s.\n * @remarks\n * This is currently used for locking regular transactions.\n * This ensures that all queries are executed at once/batched.\n * Even if middlewares are in use, they'll all execute at once.\n * @param knock the amount of awaits to open the promise\n * @param cb the callback to execute and value to return\n * @returns\n */\nexport function getLockCountPromise<V = void>(knock: number, cb: () => V | void = () => {}) {\n let resolve: (v: V | void) => void\n const lock = new Promise<V | void>((res) => (resolve = res))\n\n return {\n then(onFulfilled) {\n if (--knock === 0) resolve(cb())\n\n return onFulfilled?.(lock as unknown as V | void)\n },\n } as PromiseLike<V | void>\n}\n", "type LogLevel = 'info' | 'query' | 'warn' | 'error'\ntype LogDefinition = {\n level: LogLevel\n emit: 'stdout' | 'event'\n}\n\nexport function getLogLevel(log: LogLevel | Array<LogLevel | LogDefinition>): LogLevel | undefined {\n if (typeof log === 'string') {\n return log\n }\n return log.reduce<LogLevel | undefined>((acc, curr) => {\n const currentLevel = typeof curr === 'string' ? curr : curr.level\n if (currentLevel === 'query') {\n return acc\n }\n if (!acc) {\n return currentLevel\n }\n if (curr === 'info' || acc === 'info') {\n // info has precedence\n return 'info'\n }\n return currentLevel\n }, undefined)\n}\n", "import { Context } from '@opentelemetry/api'\nimport { deserializeJsonResponse } from '@prisma/client-engine-runtime'\nimport { hasBatchIndex } from '@prisma/client-runtime-utils'\nimport { Debug } from '@prisma/debug'\nimport { assertNever } from '@prisma/internals'\nimport stripAnsi from 'strip-ansi'\n\nimport {\n EngineValidationError,\n InteractiveTransactionOptions,\n JsonQuery,\n LogEmitter,\n TransactionOptions,\n} from '../runtime/core/engines'\nimport {\n PrismaClientInitializationError,\n PrismaClientKnownRequestError,\n PrismaClientRustPanicError,\n PrismaClientUnknownRequestError,\n} from '.'\nimport { AccelerateExtensionFetchDecorator } from './core/engines/common/Engine'\nimport { QueryEngineResultData } from './core/engines/common/types/QueryEngine'\nimport { throwValidationException } from './core/errorRendering/throwValidationException'\nimport { createApplyBatchExtensionsFunction } from './core/extensions/applyQueryExtensions'\nimport { MergedExtensionsList } from './core/extensions/MergedExtensionsList'\nimport { getBatchId } from './core/jsonProtocol/getBatchId'\nimport { isWrite } from './core/jsonProtocol/isWrite'\nimport { GlobalOmitOptions } from './core/jsonProtocol/serializeJsonQuery'\nimport { PrismaPromiseInteractiveTransaction, PrismaPromiseTransaction } from './core/request/PrismaPromise'\nimport { Action, JsArgs } from './core/types/exported/JsApi'\nimport { DataLoader } from './DataLoader'\nimport type { Client, Unpacker } from './getPrismaClient'\nimport { CallSite } from './utils/CallSite'\nimport { createErrorMessageWithContext } from './utils/createErrorMessageWithContext'\nimport { deepGet } from './utils/deep-set'\nimport { deserializeRawResult, RawResponse } from './utils/deserializeRawResults'\n\nconst debug = Debug('prisma:client:request_handler')\n\nexport type RequestParams = {\n modelName?: string\n action: Action\n protocolQuery: JsonQuery\n dataPath: string[]\n clientMethod: string\n callsite?: CallSite\n transaction?: PrismaPromiseTransaction\n extensions: MergedExtensionsList\n args?: any\n headers?: Record<string, string>\n unpacker?: Unpacker\n otelParentCtx?: Context\n otelChildCtx?: Context\n globalOmit?: GlobalOmitOptions\n customDataProxyFetch?: AccelerateExtensionFetchDecorator\n}\n\nexport type HandleErrorParams = {\n args: JsArgs\n error: any\n clientMethod: string\n callsite?: CallSite\n transaction?: PrismaPromiseTransaction\n modelName?: string\n globalOmit?: GlobalOmitOptions\n}\n\nexport class RequestHandler {\n client: Client\n dataloader: DataLoader<RequestParams>\n private logEmitter?: LogEmitter\n\n constructor(client: Client, logEmitter?: LogEmitter) {\n this.logEmitter = logEmitter\n this.client = client\n\n this.dataloader = new DataLoader({\n batchLoader: createApplyBatchExtensionsFunction(async ({ requests, customDataProxyFetch }) => {\n const { transaction, otelParentCtx } = requests[0]\n const queries = requests.map((r) => r.protocolQuery)\n const traceparent = this.client._tracingHelper.getTraceParent(otelParentCtx)\n\n // TODO: pass the child information to QE for it to issue links to queries\n // const links = requests.map((r) => trace.getSpanContext(r.otelChildCtx!))\n\n const containsWrite = requests.some((r) => isWrite(r.protocolQuery.action))\n\n const results = await this.client._engine.requestBatch(queries, {\n traceparent,\n transaction: getTransactionOptions(transaction),\n containsWrite,\n customDataProxyFetch,\n })\n\n return results.map((result, i) => {\n if (result instanceof Error) {\n return result\n }\n\n try {\n return this.mapQueryEngineResult(requests[i], result)\n } catch (error) {\n return error\n }\n })\n }),\n\n singleLoader: async (request) => {\n const interactiveTransaction =\n request.transaction?.kind === 'itx' ? getItxTransactionOptions(request.transaction) : undefined\n\n const response = await this.client._engine.request(request.protocolQuery, {\n traceparent: this.client._tracingHelper.getTraceParent(),\n interactiveTransaction,\n isWrite: isWrite(request.protocolQuery.action),\n customDataProxyFetch: request.customDataProxyFetch,\n })\n return this.mapQueryEngineResult(request, response)\n },\n\n batchBy: (request) => {\n if (request.transaction?.id) {\n return `transaction-${request.transaction.id}`\n }\n\n return getBatchId(request.protocolQuery)\n },\n\n batchOrder(requestA, requestB) {\n if (requestA.transaction?.kind === 'batch' && requestB.transaction?.kind === 'batch') {\n return requestA.transaction.index - requestB.transaction.index\n }\n return 0\n },\n })\n }\n\n async request(params: RequestParams) {\n try {\n return await this.dataloader.request(params)\n } catch (error) {\n const { clientMethod, callsite, transaction, args, modelName } = params\n this.handleAndLogRequestError({\n error,\n clientMethod,\n callsite,\n transaction,\n args,\n modelName,\n globalOmit: params.globalOmit,\n })\n }\n }\n\n mapQueryEngineResult({ dataPath, unpacker }: RequestParams, response: QueryEngineResultData<any>) {\n const data = response?.data\n\n /**\n * Unpack\n */\n const result = this.unpack(data, dataPath, unpacker)\n if (process.env.PRISMA_CLIENT_GET_TIME) {\n return { data: result }\n }\n return result\n }\n\n /**\n * Handles the error and logs it, logging the error is done synchronously waiting for the event\n * handlers to finish.\n */\n handleAndLogRequestError(params: HandleErrorParams): never {\n try {\n this.handleRequestError(params)\n } catch (err) {\n if (this.logEmitter) {\n this.logEmitter.emit('error', { message: err.message, target: params.clientMethod, timestamp: new Date() })\n }\n throw err\n }\n }\n\n handleRequestError({\n error,\n clientMethod,\n callsite,\n transaction,\n args,\n modelName,\n globalOmit,\n }: HandleErrorParams): never {\n debug(error)\n\n if (isMismatchingBatchIndex(error, transaction)) {\n // if this is batch error and current request was not it's cause, we don't add\n // context information to the error: this wasn't a request that caused batch to fail\n throw error\n }\n\n if (error instanceof PrismaClientKnownRequestError && isValidationError(error)) {\n const validationError = convertValidationError(error.meta as EngineValidationError)\n throwValidationException({\n args,\n errors: [validationError],\n callsite,\n errorFormat: this.client._errorFormat,\n originalMethod: clientMethod,\n clientVersion: this.client._clientVersion,\n globalOmit,\n })\n }\n\n let message = error.message\n if (callsite) {\n message = createErrorMessageWithContext({\n callsite,\n originalMethod: clientMethod,\n isPanic: error.isPanic,\n showColors: this.client._errorFormat === 'pretty',\n message,\n })\n }\n\n message = this.sanitizeMessage(message)\n // TODO: Do request with callsite instead, so we don't need to rethrow\n if (error.code) {\n const meta = modelName ? { modelName, ...error.meta } : error.meta\n throw new PrismaClientKnownRequestError(message, {\n code: error.code,\n clientVersion: this.client._clientVersion,\n meta,\n batchRequestIdx: error.batchRequestIdx,\n })\n } else if (error.isPanic) {\n throw new PrismaClientRustPanicError(message, this.client._clientVersion)\n } else if (error instanceof PrismaClientUnknownRequestError) {\n throw new PrismaClientUnknownRequestError(message, {\n clientVersion: this.client._clientVersion,\n batchRequestIdx: error.batchRequestIdx,\n })\n } else if (error instanceof PrismaClientInitializationError) {\n throw new PrismaClientInitializationError(message, this.client._clientVersion)\n } else if (error instanceof PrismaClientRustPanicError) {\n throw new PrismaClientRustPanicError(message, this.client._clientVersion)\n }\n\n error.clientVersion = this.client._clientVersion\n\n throw error\n }\n\n sanitizeMessage(message) {\n if (this.client._errorFormat && this.client._errorFormat !== 'pretty') {\n return stripAnsi(message)\n }\n return message\n }\n\n unpack(data: unknown, dataPath: string[], unpacker?: Unpacker) {\n if (!data) {\n return data\n }\n if (data['data']) {\n data = data['data']\n }\n\n if (!data) {\n return data\n }\n const operation = Object.keys(data)[0]\n const response = Object.values(data)[0]\n const pathForGet = dataPath.filter((key) => key !== 'select' && key !== 'include')\n const extractedResponse = deepGet(response, pathForGet)\n const deserializedResponse =\n operation === 'queryRaw'\n ? deserializeRawResult(extractedResponse as RawResponse)\n : (deserializeJsonResponse(extractedResponse) as unknown)\n\n return unpacker ? unpacker(deserializedResponse) : deserializedResponse\n }\n\n get [Symbol.toStringTag]() {\n return 'RequestHandler'\n }\n}\n\nfunction getTransactionOptions<PayloadType>(\n transaction?: PrismaPromiseTransaction<PayloadType>,\n): TransactionOptions<PayloadType> | undefined {\n if (!transaction) {\n return undefined\n }\n\n if (transaction.kind === 'batch') {\n return {\n kind: 'batch',\n options: {\n isolationLevel: transaction.isolationLevel,\n },\n }\n }\n\n if (transaction.kind === 'itx') {\n return {\n kind: 'itx',\n options: getItxTransactionOptions(transaction),\n }\n }\n\n assertNever(transaction, 'Unknown transaction kind')\n}\n\nfunction getItxTransactionOptions<PayloadType>(\n transaction: PrismaPromiseInteractiveTransaction<PayloadType>,\n): InteractiveTransactionOptions<PayloadType> {\n return {\n id: transaction.id,\n payload: transaction.payload,\n }\n}\n\nfunction isMismatchingBatchIndex(error: any, transaction: PrismaPromiseTransaction | undefined) {\n return hasBatchIndex(error) && transaction?.kind === 'batch' && error.batchRequestIdx !== transaction.index\n}\n\nfunction isValidationError(error: PrismaClientKnownRequestError) {\n return (\n error.code === 'P2009' || // validation error\n error.code === 'P2012' // required argument missing\n )\n}\n\n/**\n * Engine validation errors include extra segment for selectionPath - root query field.\n * This function removes it (since it does not exist on js arguments). In case of `Union`\n * error type, removes heading element from selectionPath of nested errors as well.\n * @param error\n * @returns\n */\nfunction convertValidationError(error: EngineValidationError): EngineValidationError {\n if (error.kind === 'Union') {\n return {\n kind: 'Union',\n errors: error.errors.map(convertValidationError),\n }\n }\n\n if (Array.isArray(error['selectionPath'])) {\n const [, ...selectionPath] = error['selectionPath']\n\n return {\n ...error,\n selectionPath,\n } as EngineValidationError\n }\n\n return error\n}\n", "import { JsonQuery } from '../engines'\n\nexport function getBatchId(query: JsonQuery): string | undefined {\n if (query.action !== 'findUnique' && query.action !== 'findUniqueOrThrow') {\n return undefined\n }\n const parts: string[] = []\n if (query.modelName) {\n parts.push(query.modelName)\n }\n\n if (query.query.arguments) {\n parts.push(buildKeysString(query.query.arguments))\n }\n parts.push(buildKeysString(query.query.selection))\n\n return parts.join('')\n}\n\nfunction buildKeysString(obj: object): string {\n const keysArray = Object.keys(obj)\n .sort()\n .map((key) => {\n const value = obj[key]\n if (typeof value === 'object' && value !== null) {\n return `(${key} ${buildKeysString(value)})`\n }\n return key\n })\n\n return `(${keysArray.join(' ')})`\n}\n", "import { JsonQueryAction } from '../engines'\n\nconst writeMap: Record<JsonQueryAction, boolean> = {\n aggregate: false,\n aggregateRaw: false,\n createMany: true,\n createManyAndReturn: true,\n createOne: true,\n deleteMany: true,\n deleteOne: true,\n executeRaw: true,\n findFirst: false,\n findFirstOrThrow: false,\n findMany: false,\n findRaw: false,\n findUnique: false,\n findUniqueOrThrow: false,\n groupBy: false,\n queryRaw: false,\n runCommandRaw: true,\n updateMany: true,\n updateManyAndReturn: true,\n updateOne: true,\n upsertOne: true,\n}\n\nexport function isWrite(action: JsonQueryAction): boolean {\n return writeMap[action]\n}\n", "interface Job {\n resolve: (data: any) => void\n reject: (data: any) => void\n request: any\n}\n\nexport type DataLoaderOptions<T> = {\n singleLoader: (request: T) => Promise<any>\n batchLoader: (request: T[]) => Promise<any[]>\n batchBy: (request: T) => string | undefined\n // Specifies the order in which requests in a batch would\n // be sorted. See Array.prototype.sort callback\n batchOrder: (requestA: T, requestB: T) => number\n}\n\nexport class DataLoader<T = unknown> {\n batches: { [key: string]: Job[] }\n private tickActive = false\n constructor(private options: DataLoaderOptions<T>) {\n this.batches = {}\n }\n\n request(request: T): Promise<any> {\n const hash = this.options.batchBy(request)\n if (!hash) {\n return this.options.singleLoader(request)\n }\n if (!this.batches[hash]) {\n this.batches[hash] = []\n\n // make sure, that we only tick once at a time\n if (!this.tickActive) {\n this.tickActive = true\n process.nextTick(() => {\n this.dispatchBatches()\n this.tickActive = false\n })\n }\n }\n\n return new Promise((resolve, reject) => {\n this.batches[hash].push({\n request,\n resolve,\n reject,\n })\n })\n }\n\n private dispatchBatches() {\n for (const key in this.batches) {\n const batch = this.batches[key]\n delete this.batches[key]\n\n // only batch if necessary\n // this might occur, if there's e.g. only 1 findUnique in the batch\n if (batch.length === 1) {\n this.options\n .singleLoader(batch[0].request)\n .then((result) => {\n if (result instanceof Error) {\n batch[0].reject(result)\n } else {\n batch[0].resolve(result)\n }\n })\n .catch((e) => {\n batch[0].reject(e)\n })\n } else {\n batch.sort((a, b) => this.options.batchOrder(a.request, b.request))\n this.options\n .batchLoader(batch.map((j) => j.request))\n .then((results) => {\n if (results instanceof Error) {\n for (let i = 0; i < batch.length; i++) {\n batch[i].reject(results)\n }\n } else {\n for (let i = 0; i < batch.length; i++) {\n const value = results[i]\n if (value instanceof Error) {\n batch[i].reject(value)\n } else {\n batch[i].resolve(value)\n }\n }\n }\n })\n .catch((e) => {\n for (let i = 0; i < batch.length; i++) {\n batch[i].reject(e)\n }\n })\n }\n }\n }\n\n get [Symbol.toStringTag]() {\n return 'DataLoader'\n }\n}\n", "import { Decimal } from '@prisma/client-runtime-utils'\nimport type { QueryIntrospectionBuiltinType } from '@prisma/generator'\n\nexport type RawResponse = {\n columns: string[]\n types: QueryIntrospectionBuiltinType[]\n rows: unknown[][]\n}\n\nfunction deserializeValue(type: QueryIntrospectionBuiltinType, value: unknown): unknown {\n if (value === null) {\n return value\n }\n\n switch (type) {\n case 'bigint':\n return BigInt(value as string)\n\n case 'bytes': {\n const { buffer, byteOffset, byteLength } = Buffer.from(value as string, 'base64')\n return new Uint8Array(buffer, byteOffset, byteLength)\n }\n\n case 'decimal':\n return new Decimal(value as string)\n\n case 'datetime':\n case 'date':\n return new Date(value as string)\n\n case 'time':\n return new Date(`1970-01-01T${value}Z`)\n\n case 'bigint-array':\n return (value as unknown[]).map((v: unknown) => deserializeValue('bigint', v))\n case 'bytes-array':\n return (value as unknown[]).map((v: unknown) => deserializeValue('bytes', v))\n case 'decimal-array':\n return (value as unknown[]).map((v: unknown) => deserializeValue('decimal', v))\n case 'datetime-array':\n return (value as unknown[]).map((v: unknown) => deserializeValue('datetime', v))\n case 'date-array':\n return (value as unknown[]).map((v: unknown) => deserializeValue('date', v))\n case 'time-array':\n return (value as unknown[]).map((v: unknown) => deserializeValue('time', v))\n\n default:\n return value\n }\n}\n\ntype DeserializedResponse = Array<Record<string, unknown>>\n\nexport function deserializeRawResult(response: RawResponse): DeserializedResponse {\n const deserializedResponse: DeserializedResponse = []\n // Performance optimization. See https://github.com/brianc/node-postgres/issues/3042\n const prebuiltEmptyObject = createPrebuiltEmptyResultObject(response)\n\n for (let i = 0; i < response.rows.length; i++) {\n const row = response.rows[i]\n const mappedRow = { ...prebuiltEmptyObject } as Record<string, unknown>\n\n for (let j = 0; j < row.length; j++) {\n mappedRow[response.columns[j]] = deserializeValue(response.types[j], row[j])\n }\n\n deserializedResponse.push(mappedRow)\n }\n\n return deserializedResponse\n}\n\nfunction createPrebuiltEmptyResultObject(response: RawResponse): Record<string, null> {\n const row = {}\n\n for (let i = 0; i < response.columns.length; i++) {\n row[response.columns[i]] = null\n }\n\n return row\n}\n", "import { version } from '../../../package.json'\n\nexport const clientVersion = version as string\n", "import { GetPrismaClientConfig, RuntimeDataModel, RuntimeModel, uncapitalize } from '@prisma/client-common'\nimport leven from 'js-levenshtein'\n\nimport { buildArgumentsRenderingTree, renderArgsTree } from '../core/errorRendering/ArgumentsRenderingTree'\nimport { PrismaClientConstructorValidationError } from '../core/errors/PrismaClientConstructorValidationError'\nimport type { ErrorFormat, LogLevel, PrismaClientOptions } from '../getPrismaClient'\n\nconst knownProperties = [\n 'errorFormat',\n 'adapter',\n 'accelerateUrl',\n 'log',\n 'transactionOptions',\n 'omit',\n 'comments',\n '__internal',\n]\nconst errorFormats: ErrorFormat[] = ['pretty', 'colorless', 'minimal']\nconst logLevels: LogLevel[] = ['info', 'query', 'warn', 'error']\n\ntype OmitValidationError =\n | { kind: 'UnknownModel'; modelKey: string }\n | { kind: 'UnknownField'; modelKey: string; fieldName: string }\n | { kind: 'RelationInOmit'; modelKey: string; fieldName: string }\n | { kind: 'InvalidFieldValue'; modelKey: string; fieldName: string }\n\n/**\n * Subset of `GetPrismaClientConfig` which is used during validation.\n * Feel free to allow more properties when necessary but don't forget to add\n * them in the mock config in `validatePrismaClientOptions.test.ts`.\n */\nexport type ClientConfig = Pick<GetPrismaClientConfig, 'previewFeatures' | 'runtimeDataModel'>\n\nconst validators: {\n [K in keyof PrismaClientOptions]-?: (option: PrismaClientOptions[K], config: ClientConfig) => void\n} = {\n adapter: () => {},\n accelerateUrl: (accelerateUrl) => {\n if (accelerateUrl === undefined) {\n return\n }\n\n if (typeof accelerateUrl !== 'string') {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${JSON.stringify(accelerateUrl)} for \"accelerateUrl\" provided to PrismaClient constructor.`,\n )\n }\n\n if (accelerateUrl.trim().length === 0) {\n throw new PrismaClientConstructorValidationError(\n `\"accelerateUrl\" provided to PrismaClient constructor must be a non-empty string.`,\n )\n }\n },\n errorFormat: (options) => {\n if (!options) {\n return\n }\n if (typeof options !== 'string') {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${JSON.stringify(options)} for \"errorFormat\" provided to PrismaClient constructor.`,\n )\n }\n if (!errorFormats.includes(options as ErrorFormat)) {\n const didYouMean = getDidYouMean(options, errorFormats)\n throw new PrismaClientConstructorValidationError(\n `Invalid errorFormat ${options} provided to PrismaClient constructor.${didYouMean}`,\n )\n }\n },\n log: (options) => {\n if (!options) {\n return\n }\n if (!Array.isArray(options)) {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${JSON.stringify(options)} for \"log\" provided to PrismaClient constructor.`,\n )\n }\n\n function validateLogLevel(level: any) {\n if (typeof level === 'string') {\n if (!logLevels.includes(level as LogLevel)) {\n const didYouMean = getDidYouMean(level, logLevels)\n throw new PrismaClientConstructorValidationError(\n `Invalid log level \"${level}\" provided to PrismaClient constructor.${didYouMean}`,\n )\n }\n }\n }\n\n for (const option of options) {\n validateLogLevel(option)\n\n const logValidators = {\n level: validateLogLevel,\n emit: (value) => {\n const emits = ['stdout', 'event']\n if (!emits.includes(value)) {\n const didYouMean = getDidYouMean(value, emits)\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${JSON.stringify(\n value,\n )} for \"emit\" in logLevel provided to PrismaClient constructor.${didYouMean}`,\n )\n }\n },\n }\n\n if (option && typeof option === 'object') {\n for (const [key, value] of Object.entries(option)) {\n if (logValidators[key]) {\n logValidators[key](value)\n } else {\n throw new PrismaClientConstructorValidationError(\n `Invalid property ${key} for \"log\" provided to PrismaClient constructor`,\n )\n }\n }\n }\n }\n },\n transactionOptions: (options: any) => {\n if (!options) {\n return\n }\n\n const maxWait = options.maxWait\n if (maxWait != null && maxWait <= 0) {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${maxWait} for maxWait in \"transactionOptions\" provided to PrismaClient constructor. maxWait needs to be greater than 0`,\n )\n }\n\n const timeout = options.timeout\n if (timeout != null && timeout <= 0) {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${timeout} for timeout in \"transactionOptions\" provided to PrismaClient constructor. timeout needs to be greater than 0`,\n )\n }\n },\n omit: (options: unknown, config) => {\n if (typeof options !== 'object') {\n throw new PrismaClientConstructorValidationError(`\"omit\" option is expected to be an object.`)\n }\n if (options === null) {\n throw new PrismaClientConstructorValidationError(`\"omit\" option can not be \\`null\\``)\n }\n\n const validationErrors: OmitValidationError[] = []\n for (const [modelKey, modelConfig] of Object.entries(options)) {\n const modelOrType = getModelOrTypeByKey(modelKey, config.runtimeDataModel)\n if (!modelOrType) {\n validationErrors.push({ kind: 'UnknownModel', modelKey: modelKey })\n continue\n }\n for (const [fieldName, value] of Object.entries(modelConfig)) {\n const field = modelOrType.fields.find((field) => field.name === fieldName)\n if (!field) {\n validationErrors.push({ kind: 'UnknownField', modelKey, fieldName })\n continue\n }\n if (field.relationName) {\n validationErrors.push({ kind: 'RelationInOmit', modelKey, fieldName })\n continue\n }\n if (typeof value !== 'boolean') {\n validationErrors.push({ kind: 'InvalidFieldValue', modelKey, fieldName })\n }\n }\n }\n if (validationErrors.length > 0) {\n throw new PrismaClientConstructorValidationError(\n renderOmitValidationErrors(options as Record<string, unknown>, validationErrors),\n )\n }\n },\n comments: (options) => {\n if (options === undefined) {\n return\n }\n if (!Array.isArray(options)) {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${JSON.stringify(options)} for \"comments\" provided to PrismaClient constructor. Expected an array of SQL commenter plugins.`,\n )\n }\n for (let i = 0; i < options.length; i++) {\n if (typeof options[i] !== 'function') {\n throw new PrismaClientConstructorValidationError(\n `Invalid value at index ${i} for \"comments\" provided to PrismaClient constructor. Each plugin must be a function.`,\n )\n }\n }\n },\n __internal: (value) => {\n if (!value) {\n return\n }\n const knownKeys = ['debug', 'engine', 'configOverride']\n if (typeof value !== 'object') {\n throw new PrismaClientConstructorValidationError(\n `Invalid value ${JSON.stringify(value)} for \"__internal\" to PrismaClient constructor`,\n )\n }\n for (const [key] of Object.entries(value)) {\n if (!knownKeys.includes(key)) {\n const didYouMean = getDidYouMean(key, knownKeys)\n throw new PrismaClientConstructorValidationError(\n `Invalid property ${JSON.stringify(key)} for \"__internal\" provided to PrismaClient constructor.${didYouMean}`,\n )\n }\n }\n // TODO: Add more validation here\n // but as this is an internal, non user-facing api, it's not urgent\n },\n}\n\nfunction validateDependentOptions(options: PrismaClientOptions) {\n const adapterProvided = options.adapter !== undefined\n const accelerateUrlProvided = options.accelerateUrl !== undefined\n\n if (adapterProvided && accelerateUrlProvided) {\n throw new PrismaClientConstructorValidationError(\n `The \"adapter\" and \"accelerateUrl\" options are mutually exclusive. Please provide only one of them.`,\n )\n }\n\n if (!adapterProvided && !accelerateUrlProvided) {\n throw new PrismaClientConstructorValidationError(\n `Using engine type \"client\" requires either \"adapter\" or \"accelerateUrl\" to be provided to PrismaClient constructor.`,\n )\n }\n}\n\nexport function validatePrismaClientOptions(options: PrismaClientOptions, config: ClientConfig) {\n for (const [key, value] of Object.entries(options)) {\n if (!knownProperties.includes(key)) {\n const didYouMean = getDidYouMean(key, knownProperties)\n throw new PrismaClientConstructorValidationError(\n `Unknown property ${key} provided to PrismaClient constructor.${didYouMean}`,\n )\n }\n validators[key](value, config)\n }\n\n validateDependentOptions(options)\n}\n\nfunction getDidYouMean(str: string, options: string[]): string {\n if (options.length === 0) {\n return ''\n }\n\n if (typeof str !== 'string') {\n return ''\n }\n\n const alternative = getAlternative(str, options)\n if (!alternative) {\n return ''\n }\n\n return ` Did you mean \"${alternative}\"?`\n}\n\nfunction getAlternative(str: string, options: string[]): null | string {\n if (options.length === 0) {\n return null\n }\n\n const optionsWithDistances = options.map((value) => ({\n value,\n distance: leven(str, value),\n }))\n\n optionsWithDistances.sort((a, b) => {\n return a.distance < b.distance ? -1 : 1\n })\n\n const bestAlternative = optionsWithDistances[0]\n if (bestAlternative.distance < 3) {\n return bestAlternative.value\n }\n\n return null\n}\n\nfunction getModelOrTypeByKey(modelKey: string, runtimeDataModel: RuntimeDataModel): RuntimeModel | undefined {\n return findByKey(runtimeDataModel.models, modelKey) ?? findByKey(runtimeDataModel.types, modelKey)\n}\n\nfunction findByKey<T>(map: Record<string, T>, key: string): T | undefined {\n const foundKey = Object.keys(map).find((mapKey) => uncapitalize(mapKey) === key)\n if (foundKey) {\n return map[foundKey]\n }\n return undefined\n}\n\nfunction renderOmitValidationErrors(\n omitConfig: Record<PropertyKey, unknown>,\n validationErrors: OmitValidationError[],\n): string {\n const argsTree = buildArgumentsRenderingTree(omitConfig)\n for (const error of validationErrors) {\n switch (error.kind) {\n case 'UnknownModel':\n argsTree.arguments.getField(error.modelKey)?.markAsError()\n argsTree.addErrorMessage(() => `Unknown model name: ${error.modelKey}.`)\n break\n case 'UnknownField':\n argsTree.arguments.getDeepField([error.modelKey, error.fieldName])?.markAsError()\n argsTree.addErrorMessage(() => `Model \"${error.modelKey}\" does not have a field named \"${error.fieldName}\".`)\n break\n case 'RelationInOmit':\n argsTree.arguments.getDeepField([error.modelKey, error.fieldName])?.markAsError()\n argsTree.addErrorMessage(() => `Relations are already excluded by default and can not be specified in \"omit\".`)\n break\n case 'InvalidFieldValue':\n argsTree.arguments.getDeepFieldValue([error.modelKey, error.fieldName])?.markAsError()\n argsTree.addErrorMessage(() => `Omit field option value must be a boolean.`)\n break\n }\n }\n const { message, args } = renderArgsTree(argsTree, 'colorless')\n return `Error validating \"omit\" option:\\n\\n${args}\\n\\n${message}`\n}\n", "import { setClassName } from '@prisma/internals'\n\nexport class PrismaClientConstructorValidationError extends Error {\n constructor(message: string) {\n super(message + `\\nRead more at https://pris.ly/d/client-constructor`)\n this.name = 'PrismaClientConstructorValidationError'\n }\n get [Symbol.toStringTag]() {\n return 'PrismaClientConstructorValidationError'\n }\n}\nsetClassName(PrismaClientConstructorValidationError, 'PrismaClientConstructorValidationError')\n", "import { hasBatchIndex } from '@prisma/client-runtime-utils'\n\n/**\n * Waits for result of batch $transaction and picks the best possible error to report if any\n * of the request fails. Best error is determined as follows:\n *\n * - if engine have reported an error without batch request index, then the batch is immediately rejected\n * with this error without waiting for other promises\n * - if engine have reported and index of failed request in the batch and that index matches the position of the\n * particular request in the batch, batch is rejected with that error\n * - if batch request index is reported and it does not match current request position, wait for other requests. If no indices\n * match request positions, reject with the earliest error in the batch\n *\n * @param promises\n * @returns\n */\nexport function waitForBatch<T extends PromiseLike<unknown>[]>(\n promises: T,\n): Promise<{ [K in keyof T]: Awaited<T[K]> }> {\n if (promises.length === 0) {\n return Promise.resolve([] as { [K in keyof T]: Awaited<T[K]> })\n }\n return new Promise((resolve, reject) => {\n const successfulResults = new Array(promises.length) as { [K in keyof T]: Awaited<T[K]> }\n let bestError: unknown = null\n let done = false\n let settledPromisesCount = 0\n\n const settleOnePromise = () => {\n if (done) {\n return\n }\n settledPromisesCount++\n if (settledPromisesCount === promises.length) {\n done = true\n if (bestError) {\n reject(bestError)\n } else {\n resolve(successfulResults)\n }\n }\n }\n\n const immediatelyReject = (error: unknown) => {\n if (!done) {\n done = true\n reject(error)\n }\n }\n\n for (let i = 0; i < promises.length; i++) {\n promises[i].then(\n (result) => {\n successfulResults[i] = result\n settleOnePromise()\n },\n (error) => {\n if (!hasBatchIndex(error)) {\n immediatelyReject(error)\n return\n }\n\n if (error.batchRequestIdx === i) {\n immediatelyReject(error)\n } else {\n if (!bestError) {\n bestError = error\n }\n settleOnePromise()\n }\n },\n )\n }\n })\n}\n", "/**\n * List of properties that won't throw exception on access and return undefined instead\n */\nconst allowList = new Set([\n 'toJSON', // used by JSON.stringify\n '$$typeof', // used by old React tooling\n 'asymmetricMatch', // used by Jest\n Symbol.iterator, // used by various JS constructs/methods\n Symbol.toStringTag, // Used by .toString()\n Symbol.isConcatSpreadable, // Used by Array#concat,\n Symbol.toPrimitive, // Used when getting converted to primitive values\n])\n/**\n * Generates more strict variant of an enum which, unlike regular enum,\n * throws on non-existing property access. This can be useful in following situations:\n * - we have an API, that accepts both `undefined` and `SomeEnumType` as an input\n * - enum values are generated dynamically from DMMF.\n *\n * In that case, if using normal enums and no compile-time typechecking, using non-existing property\n * will result in `undefined` value being used, which will be accepted. Using strict enum\n * in this case will help to have a runtime exception, telling you that you are probably doing something wrong.\n *\n * Note: if you need to check for existence of a value in the enum you can still use either\n * `in` operator or `hasOwnProperty` function.\n *\n * @param definition\n * @returns\n */\nexport function makeStrictEnum<T extends Record<PropertyKey, string | number>>(definition: T): T {\n return new Proxy(definition, {\n get(target, property) {\n if (property in target) {\n return target[property]\n }\n if (allowList.has(property)) {\n return undefined\n }\n throw new TypeError(`Invalid enum value: ${String(property)}`)\n },\n })\n}\n", "// https://runtime-keys.proposal.wintercg.org/\nexport type RuntimeName = 'workerd' | 'deno' | 'netlify' | 'node' | 'bun' | 'edge-light' | '' /* unknown */\n\n/**\n * Indicates if running in Node.js or a Node.js compatible runtime.\n *\n * **Note:** When running code in Bun and Deno with Node.js compatibility mode, `isNode` flag will be also `true`, indicating running in a Node.js compatible runtime.\n */\nconst isNode = () => globalThis.process?.release?.name === 'node'\n\n/**\n * Indicates if running in Bun runtime.\n */\nconst isBun = () => !!globalThis.Bun || !!globalThis.process?.versions?.bun\n\n/**\n * Indicates if running in Deno runtime.\n */\nconst isDeno = () => !!globalThis.Deno\n\n/**\n * Indicates if running in Netlify runtime.\n */\nconst isNetlify = () => typeof globalThis.Netlify === 'object'\n\n/**\n * Indicates if running in EdgeLight (Vercel Edge) runtime.\n */\nconst isEdgeLight = () => typeof globalThis.EdgeRuntime === 'object'\n\n/**\n * Indicates if running in Cloudflare Workers runtime.\n * See: https://developers.cloudflare.com/workers/runtime-apis/web-standards/#navigatoruseragent\n */\nconst isWorkerd = () => globalThis.navigator?.userAgent === 'Cloudflare-Workers'\n\nfunction detectRuntime(): RuntimeName {\n // Note: we're currently not taking 'fastly' into account. Why?\n const runtimeChecks = [\n [isNetlify, 'netlify'],\n [isEdgeLight, 'edge-light'],\n [isWorkerd, 'workerd'],\n [isDeno, 'deno'],\n [isBun, 'bun'],\n [isNode, 'node'],\n ] as const\n\n const detectedRuntime =\n runtimeChecks\n // TODO: Transforming destructuring to the configured target environment ('chrome58', 'edge16', 'firefox57', 'safari11') is not supported yet,\n // so we can't write the following code yet:\n // ```\n // .flatMap(([isCurrentRuntime, runtime]) => isCurrentRuntime() ? [runtime] : [])\n // ```\n .flatMap((check) => (check[0]() ? [check[1]] : []))\n .at(0) ?? ''\n\n return detectedRuntime\n}\n\nconst runtimesPrettyNames = {\n node: 'Node.js',\n workerd: 'Cloudflare Workers',\n deno: 'Deno and Deno Deploy',\n netlify: 'Netlify Edge Functions',\n 'edge-light':\n 'Edge Runtime (Vercel Edge Functions, Vercel Edge Middleware, Next.js (Pages Router) Edge API Routes, Next.js (App Router) Edge Route Handlers or Next.js Middleware)',\n} as const\n\ntype GetRuntimeOutput = {\n id: RuntimeName\n prettyName: string\n isEdge: boolean\n}\n\nexport function getRuntime(): GetRuntimeOutput {\n const runtimeId = detectRuntime()\n\n return {\n id: runtimeId,\n // Fallback to the runtimeId if the runtime is not in the list\n prettyName: runtimesPrettyNames[runtimeId] || runtimeId,\n isEdge: ['workerd', 'deno', 'netlify', 'edge-light'].includes(runtimeId),\n }\n}\n", "import * as Extensions from './core/extensions'\nimport * as Public from './core/public'\nimport * as Types from './core/types'\n\nexport { type Types }\nexport { Extensions }\nexport { Public }\n\nexport { type JsonBatchQuery, type JsonQuery } from './core/engines'\nexport { serializeJsonQuery } from './core/jsonProtocol/serializeJsonQuery'\nexport { createParam } from './core/model/Param'\nexport { defineDmmfProperty } from './core/runtimeDataModel'\nexport type * from './core/types/exported'\nexport type { ITXClientDenyList } from './core/types/exported/itxClientDenyList'\nexport { skip } from './core/types/exported/Skip'\nexport { makeTypedQueryFactory } from './core/types/exported/TypedSql'\nexport type { PrismaClientOptions } from './getPrismaClient'\nexport { getPrismaClient } from './getPrismaClient'\nexport { makeStrictEnum } from './strictEnum'\nexport { deserializeRawResult } from './utils/deserializeRawResults'\nexport { getRuntime } from './utils/getRuntime'\nexport {\n type BaseDMMF,\n dmmfToRuntimeDataModel,\n type GetPrismaClientConfig,\n type Operation,\n type RuntimeDataModel,\n} from '@prisma/client-common'\nexport { deserializeJsonResponse } from '@prisma/client-engine-runtime'\nexport type { RawValue, Value } from '@prisma/client-runtime-utils'\nexport type { AnyNullClass, DbNullClass, JsonNullClass } from '@prisma/client-runtime-utils'\nexport {\n PrismaClientInitializationError,\n PrismaClientKnownRequestError,\n PrismaClientRustPanicError,\n PrismaClientUnknownRequestError,\n PrismaClientValidationError,\n} from '@prisma/client-runtime-utils'\nexport { empty, join, raw, Sql, sql as sqltag } from '@prisma/client-runtime-utils'\nexport {\n AnyNull,\n DbNull,\n isAnyNull,\n isDbNull,\n isJsonNull,\n JsonNull,\n NullTypes,\n ObjectEnumValue,\n} from '@prisma/client-runtime-utils'\nexport { Decimal } from '@prisma/client-runtime-utils'\nexport { Debug } from '@prisma/debug'\nexport * as DMMF from '@prisma/dmmf'\nexport type { SqlDriverAdapterFactory } from '@prisma/driver-adapter-utils'\nexport { warnOnce } from '@prisma/internals'\nexport type {\n SqlCommenterContext,\n SqlCommenterPlugin,\n SqlCommenterQueryInfo,\n SqlCommenterSingleQueryInfo,\n SqlCommenterTags,\n} from '@prisma/sqlcommenter'\n"],
|
|
5
5
|
"mappings": "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",
|
|
6
6
|
"names": ["require_package", "__commonJSMin", "exports", "module", "require_engines_version", "__commonJSMin", "exports", "require_min_indent", "__commonJSMin", "exports", "module", "string", "match", "a", "require_indent_string", "__commonJSMin", "exports", "module", "string", "count", "options", "regex", "require_new_github_issue_url", "__commonJSMin", "exports", "module", "options", "repoUrl", "url", "types", "type", "value", "require_js_levenshtein", "__commonJSMin", "exports", "module", "_min", "d0", "d1", "d2", "bx", "ay", "a", "b", "tmp", "la", "lb", "offset", "x", "y", "d3", "dd", "dy", "bx0", "bx1", "bx2", "bx3", "vector", "len", "init_TypeBuilder", "__esmMin", "init_KeyType", "__esmMin", "exports", "anumber", "abytes", "ahash", "aexists", "aoutput", "n", "isBytes", "a", "b", "lengths", "h", "instance", "checkFinished", "out", "min", "exports", "fromBig", "split", "add", "U32_MASK64", "_32n", "n", "le", "lst", "Ah", "Al", "h", "l", "toBig", "shrSH", "_l", "s", "shrSL", "rotrSH", "rotrSL", "rotrBH", "rotrBL", "rotr32H", "_h", "rotr32L", "rotlSH", "rotlSL", "rotlBH", "rotlBL", "Bh", "Bl", "add3L", "Cl", "add3H", "low", "Ch", "add4L", "Dl", "add4H", "Dh", "add5L", "El", "add5H", "Eh", "u64", "nc", "exports", "exports", "isBytes", "u8", "u32", "createView", "rotr", "rotl", "byteSwap", "byteSwap32", "bytesToHex", "hexToBytes", "asyncLoop", "utf8ToBytes", "toBytes", "concatBytes", "checkOpts", "wrapConstructor", "wrapConstructorWithOpts", "wrapXOFConstructorWithOpts", "randomBytes", "crypto_1", "_assert_js_1", "a", "arr", "word", "shift", "n", "i", "hexes", "_", "bytes", "hex", "asciis", "asciiToBase16", "ch", "hl", "al", "array", "ai", "hi", "n1", "n2", "char", "nextTick", "iters", "tick", "cb", "ts", "diff", "str", "data", "arrays", "sum", "res", "pad", "Hash", "defaults", "opts", "hashCons", "hashC", "msg", "tmp", "bytesLength", "exports", "keccakP", "_assert_js_1", "_u64_js_1", "utils_js_1", "SHA3_PI", "SHA3_ROTL", "_SHA3_IOTA", "_0n", "_1n", "_2n", "_7n", "_256n", "_0x71n", "round", "R", "x", "y", "t", "j", "SHA3_IOTA_H", "SHA3_IOTA_L", "rotlH", "h", "l", "s", "rotlL", "rounds", "B", "idx1", "idx0", "B0", "B1", "Th", "Tl", "curH", "curL", "shift", "PI", "Keccak", "_Keccak", "blockLen", "suffix", "outputLen", "enableXOF", "data", "state", "len", "pos", "take", "i", "out", "bufferOut", "bytes", "to", "gen", "genShake", "opts", "require_src", "__commonJSMin", "exports", "module", "sha3", "defaultLength", "bigLength", "createEntropy", "length", "random", "entropy", "bufToBigInt", "buf", "bits", "value", "i", "bi", "hash", "input", "alphabet", "x", "randomLetter", "createFingerprint", "globalObj", "globals", "sourceString", "createCounter", "count", "initialCountMax", "init", "counter", "fingerprint", "firstLetter", "time", "salt", "hashInput", "createId", "isCuid", "id", "minLength", "maxLength", "regex", "require_cuid2", "__commonJSMin", "exports", "module", "createId", "init", "getConstants", "isCuid", "extensions_exports", "__export", "defineExtension", "getExtensionContext", "defineExtension", "ext", "client", "getExtensionContext", "that", "public_exports", "__export", "validator", "validator", "_args", "args", "Cache", "key", "value", "create", "cached", "uncapitalize", "self", "keyBy", "collection", "prop", "acc", "obj", "key", "lazyProperty", "compute", "resultContainer", "dmmfToRuntimeDataModel", "dmmfDataModel", "buildMapForRuntime", "buildMapForRuntime", "list", "result", "name", "rest", "isAnyNull", "isDbNull", "isJsonNull", "ObjectEnumValue", "colors_exports", "__export", "$", "bgBlack", "bgBlue", "bgCyan", "bgGreen", "bgMagenta", "bgRed", "bgWhite", "bgYellow", "black", "blue", "bold", "cyan", "dim", "gray", "green", "grey", "hidden", "inverse", "italic", "magenta", "red", "reset", "strikethrough", "underline", "white", "yellow", "FORCE_COLOR", "NODE_DISABLE_COLORS", "NO_COLOR", "TERM", "isTTY", "init", "x", "y", "rgx", "open", "close", "txt", "MAX_ARGS_HISTORY", "COLORS", "argsHistory", "lastTimestamp", "lastColor", "processEnv", "topProps", "namespace", "prev", "listenedNamespaces", "s", "isListened", "listenedNamespace", "isExcluded", "args", "format", "rest", "debugCreate", "instanceProps", "debugCall", "enabled", "color", "log", "stringArgs", "arg", "safeStringify", "ms", "colors_exports", "bold", "_", "prop", "value", "Debug", "indent", "cache", "key", "getLogs", "numChars", "logs", "clearLogs", "import_min_indent", "stripIndent", "string", "indent", "minIndent", "regex", "PRISMA_POSTGRES_PROVIDER", "PRISMA_POSTGRES_PROTOCOL", "isPrismaPostgres", "connectionString", "isPrismaPostgresDev", "host", "logger_exports", "__export", "error", "info", "log", "query", "should", "tags", "warn", "tags", "red", "yellow", "cyan", "blue", "should", "log", "data", "warn", "message", "optionalParams", "info", "error", "query", "assertNever", "arg", "errorMessage", "ansiRegex", "onlyFirst", "pattern", "regex", "ansiRegex", "stripAnsi", "string", "path", "pathToPosix", "filePath", "hasOwnProperty", "object", "key", "mapObjectValues", "object", "mapper", "result", "key", "maxWithComparator", "items", "comparator", "result", "i", "setClassName", "classObject", "name", "alreadyWarned", "warnOnce", "key", "message", "args", "warn", "isDate", "value", "isValidDate", "date", "Decimal", "isDecimalJsLike", "value", "PrismaClientValidationError", "src_exports", "__export", "ModelAction", "datamodelEnumToSchemaEnum", "datamodelEnumToSchemaEnum", "datamodelEnum", "v", "ModelAction", "import_indent_string", "fs", "theme", "cyan", "s", "bold", "blue", "green", "yellow", "gray", "identity", "str", "_self", "uniqueId", "Prism", "tokens", "Token", "anyTokens", "o", "obj", "deepClone", "visited", "clone", "id", "type", "key", "v", "i", "redef", "lang", "inside", "before", "insert", "root", "grammar", "ret", "token", "newToken", "old", "value", "DFS", "callback", "objId", "property", "propertyType", "text", "language", "env", "strarr", "index", "startPos", "oneshot", "target", "patterns", "j", "pattern", "lookbehind", "greedy", "lookbehindLength", "alias", "flags", "pos", "match", "from", "to", "k", "p", "len", "delNum", "after", "args", "wrapped", "rest", "name", "hooks", "callbacks", "content", "matchedStr", "element", "getColorForSyntaxKind", "syntaxKind", "theme", "highlightTS", "str", "highlight", "Prism", "grammar", "t", "Token", "dedent", "str", "stripIndent", "SourceFileSlice", "_SourceFileSlice", "filePath", "content", "fs", "lines", "firstLine", "lineNumber", "mapFn", "idx", "newLines", "line", "i", "atLine", "str", "fromLine", "toLine", "slicedLines", "dedent", "highlighted", "highlightTS", "colorsEnabled", "red", "gray", "dim", "bold", "underline", "source", "colorsDisabled", "str", "getRawTemplateParameters", "message", "originalMethod", "isPanic", "callArguments", "getTemplateParameters", "callsite", "colors", "templateParameters", "callLocation", "contextFirstLine", "SourceFileSlice", "invocationLine", "invocationLineIndent", "getIndent", "invocationCallCode", "findPrismaActionCall", "line", "numberColumnWidth", "lineNumber", "indentValue", "indentString", "allActions", "ModelAction", "match", "openingBraceIndex", "statementStart", "spaceCount", "i", "stringifyErrorMessage", "functionName", "location", "contextLines", "lines", "introSuffix", "stringifyLocationInFile", "contextLineParts", "parts", "createErrorMessageWithContext", "args", "import_js_levenshtein", "applyUnionError", "error", "args", "globalOmit", "allErrors", "flattenUnionError", "merged", "mergeInvalidArgumentTypeErrors", "bestError", "getBestScoringError", "applyValidationError", "errorList", "invalidArgsError", "result", "key", "prevError", "uniqueConcat", "head", "tail", "errors", "maxWithComparator", "errorA", "errorB", "aPathLength", "getCombinedPathLength", "bPathLength", "getErrorTypeScore", "score", "ObjectFieldSuggestion", "name", "value", "writer", "green", "init_KeyType", "Writer", "startingIndent", "context", "value", "separator", "values", "writeItem", "item", "w", "last", "i", "line", "afterNextNewLineCallback", "callback", "symbol", "init_TypeBuilder", "ArrayField", "value", "writer", "noop", "str", "inactiveColors", "activeColors", "bold", "red", "green", "dim", "fieldsSeparator", "writer", "FormattedString", "contents", "str", "color", "writer", "paddingSize", "Value", "ArrayValue", "Value", "item", "ArrayField", "index", "writer", "output", "FormattedString", "colors", "fieldsSeparator", "ObjectValue", "_ObjectValue", "Value", "field", "suggestion", "key", "path", "head", "tail", "firstField", "segment", "nextField", "ArrayValue", "selection", "next", "thisParent", "parent", "nextParent", "select", "include", "fields", "f", "writer", "output", "FormattedString", "fieldsSeparator", "ScalarValue", "Value", "text", "writer", "string", "FormattedString", "SuggestionObjectValue", "name", "value", "writer", "green", "dim", "fieldsSeparator", "applyValidationError", "error", "args", "globalOmit", "applyMutuallyExclusiveFieldsError", "applyIncludeOnScalarError", "applyEmptySelectionError", "applyUnknownSelectionFieldError", "applyInvalidSelectionValueError", "applyUnknownArgumentError", "applyUnknownInputFieldError", "applyRequiredArgumentMissingError", "applyInvalidArgumentTypeError", "applyInvalidArgumentValueError", "applyValueTooLargeError", "applySomeFieldsMissingError", "applyTooManyFieldsGivenError", "applyUnionError", "argsTree", "object", "colors", "selectionPath", "field", "splitPath", "outputType", "ObjectFieldSuggestion", "msg", "availableOptionsMessage", "subSelection", "omit", "applyEmptySelectionErrorOmit", "applyEmptySelectionErrorSelect", "uncapitalize", "applyEmptySelectionErrorGlobalOmit", "omitValue", "selection", "isEmpty", "addSelectionSuggestions", "suggestedOmitConfig", "SuggestionObjectValue", "omitSuggestion", "parentPath", "fieldName", "fieldValue", "ObjectValue", "locateResult", "locateSelectionField", "parent", "addInclusionSuggestions", "addOmissionSuggestions", "parts", "argName", "addArgumentsSuggestions", "unknownArgumentMessage", "arg", "argParentPath", "argParent", "addInputSuggestions", "f", "options", "suggestion", "getSuggestion", "existingField", "ScalarValue", "argumentName", "objectSuggestion", "typeName", "getInputTypeName", "dependentArgumentName", "description", "expected", "joinWithPreposition", "type", "printedValue", "value", "argument", "providedArguments", "argumentsParent", "select", "include", "inputType", "path", "green", "enabled", "preposition", "items", "itemsCopy", "lastItem", "MAX_EDIT_DISTANCE", "str", "minDistance", "result", "option", "editDistance", "levenshtein", "ObjectEnumValue", "FieldRefImpl", "modelName", "name", "fieldType", "isList", "isEnum", "listPrefix", "enumPrefix", "isFieldRef", "value", "separator", "ObjectField", "name", "value", "writer", "FormattedString", "ArgumentsRenderingTree", "args", "writer", "renderer", "colors", "messageRenderer", "buildArgumentsRenderingTree", "buildInputObject", "inputObject", "object", "ObjectValue", "key", "value", "field", "ObjectField", "buildInputValue", "ScalarValue", "isDecimalJsLike", "dateStr", "isValidDate", "ObjectEnumValue", "isFieldRef", "uncapitalize", "buildInputArray", "array", "result", "ArrayValue", "item", "renderArgsTree", "argsTree", "errorFormat", "activeColors", "inactiveColors", "message", "Writer", "throwValidationException", "args", "errors", "errorFormat", "callsite", "originalMethod", "clientVersion", "globalOmit", "argsTree", "buildArgumentsRenderingTree", "error", "applyValidationError", "message", "renderedArgs", "renderArgsTree", "messageWithContext", "createErrorMessageWithContext", "PrismaClientValidationError", "dmmfToJSModelName", "name", "str", "getComputedFields", "previousComputedFields", "extension", "dmmfModelName", "jsName", "dmmfToJSModelName", "resolveDependencies", "getComputedFieldsFromModel", "computedFields", "cache", "Cache", "resolveNeeds", "fieldName", "visitedFields", "fieldDep", "mapObjectValues", "field", "name", "modelResult", "needs", "compute", "key", "composeCompute", "nextCompute", "previousCompute", "model", "computeEngineSideSelection", "selection", "result", "dependency", "computeEngineSideOmissions", "omission", "MergedExtensionsListNode", "extension", "previous", "Cache", "lazyProperty", "newCb", "dmmfModelName", "getComputedFields", "jsModelName", "dmmfToJSModelName", "operation", "prevCbs", "newCbs", "query", "MergedExtensionsList", "_MergedExtensionsList", "head", "ParamImpl", "name", "isParam", "value", "createParam", "secret", "Skip", "param", "value", "skip", "isSkip", "jsActionToProtocolAction", "STRICT_UNDEFINED_ERROR_MESSAGE", "serializeJsonQuery", "modelName", "action", "args", "runtimeDataModel", "extensions", "MergedExtensionsList", "callsite", "clientMethod", "errorFormat", "clientVersion", "previewFeatures", "globalOmit", "wrapRawValues", "context", "SerializeContext", "serializeFieldSelection", "select", "include", "omit", "serializeArgumentsObject", "serializeSelectionSet", "createExplicitSelection", "createImplicitSelection", "selectionSet", "addIncludedRelations", "omitFields", "key", "value", "isSkip", "nestedContext", "validateSelectionForUndefined", "field", "localOmit", "computedFields", "combinedOmits", "omitWithComputedFields", "computeEngineSideOmissions", "selectWithComputedFields", "computeEngineSideSelection", "serializeArgumentsValue", "jsValue", "isDate", "isValidDate", "isParam", "isFieldRef", "serializeArgumentsArray", "buffer", "byteOffset", "byteLength", "isRawParameters", "isDecimalJsLike", "ObjectEnumValue", "isDbNull", "isJsonNull", "isAnyNull", "isJSONConvertible", "object", "result", "array", "i", "itemContext", "valueName", "_SerializeContext", "params", "error", "throwValidationException", "previewFeature", "name", "fieldName", "uncapitalize", "assertNever", "defineDmmfProperty", "target", "runtimeDataModel", "dmmfLazy", "lazyProperty", "runtimeDataModelToBaseDmmf", "buildDMMFList", "map", "name", "props", "internals", "TypedSqlMarker", "TypedSql", "sql", "values", "makeTypedQueryFactory", "isTypedSql", "value", "Sql", "AsyncResource", "EventEmitter", "addObjectProperties", "object", "key", "addProperty", "key", "factory", "cacheProperties", "baseLayer", "cache", "Cache", "key", "defaultPropertyDescriptor", "defaultProxyHandlers", "ownKeys", "_ownKeys", "target", "prop", "value", "customInspect", "createCompositeProxy", "target", "layers", "keysToLayerMap", "mapKeysToLayers", "overwrittenKeys", "proxy", "prop", "layer", "targetKeys", "getExistingKeys", "layerKeys", "value", "original", "defaultPropertyDescriptor", "property", "attributes", "toLog", "keys", "key", "removeProperties", "keys", "prettyPrintArguments", "args", "tree", "buildArgumentsRenderingTree", "Writer", "inactiveColors", "UNKNOWN_FUNCTION", "parse", "stackString", "lines", "stack", "line", "parseResult", "parseChrome", "parseWinjs", "parseGecko", "parseNode", "parseJSC", "chromeRe", "chromeEvalRe", "parts", "isNative", "isEval", "submatch", "winjsRe", "geckoRe", "geckoEvalRe", "javaScriptCoreRe", "nodeRe", "DisabledCallSite", "EnabledCallSite", "stack", "frame", "parse", "t", "posixFile", "pathToPosix", "getCallSite", "errorFormat", "aggregateMap", "desugarUserArgs", "args", "_args", "desugarCountInUserArgs", "aggregateArgs", "key", "value", "aggregateMap", "createUnpacker", "data", "aggregate", "modelAction", "aggregateUnpacker", "desugarUserArgs", "args", "select", "_args", "createUnpacker", "data", "count", "modelAction", "desugarUserArgs", "args", "_args", "key", "createUnpacker", "data", "row", "groupBy", "modelAction", "applyAggregates", "client", "action", "modelAction", "userArgs", "aggregate", "count", "groupBy", "applyFieldsProxy", "modelName", "model", "scalarFieldsList", "field", "scalarFields", "keyBy", "target", "prop", "dmmfField", "FieldRefImpl", "defaultProxyHandlers", "keys", "ks", "deepGet", "o", "kp", "k", "deepSet", "v", "i", "getNextDataPath", "fluentPropName", "prevDataPath", "getNextUserArgs", "callArgs", "prevArgs", "nextDataPath", "deepSet", "applyFluent", "client", "dmmfModelName", "modelAction", "prevUserArgs", "dmmfModelFieldMap", "acc", "field", "userArgs", "callsite", "getCallSite", "nextUserArgs", "prismaPromise", "ownKeys", "getOwnKeys", "target", "prop", "modelArgs", "dataArgs", "defaultProxyHandlers", "fluentProps", "aggregateProps", "applyModel", "client", "dmmfModelName", "modelExtensions", "layers", "modelActionsLayer", "fieldsPropertyLayer", "addObjectProperties", "addProperty", "createCompositeProxy", "jsModelName", "dmmfToJSModelName", "ownKeys", "ModelAction", "key", "dmmfActionName", "action", "paramOverrides", "userArgs", "callSite", "getCallSite", "transaction", "params", "applyFluent", "isValidAggregateName", "applyAggregates", "cacheProperties", "model", "applyFieldsProxy", "jsToDMMFModelName", "name", "str", "rawClient", "applyModelsAndClientExtensions", "client", "layers", "rootLayer", "modelsLayer", "addProperty", "clientExtensions", "addObjectProperties", "createCompositeProxy", "prototype", "allKeys", "prop", "dmmfModelKeys", "jsModelKeys", "dmmfToJSModelName", "cacheProperties", "dmmfModelName", "jsToDMMFModelName", "applyModel", "key", "unApplyModelsAndClientExtensions", "$extends", "extension", "newClient", "applyModelsAndClientExtensions", "applyResultExtensions", "result", "modelName", "select", "omit", "extensions", "computedFields", "computedPropertiesLayers", "maskingLayers", "field", "toMask", "prop", "removeProperties", "areNeedsMet", "computedPropertyLayer", "createCompositeProxy", "neededProperties", "property", "hasOwnProperty", "cacheProperties", "addProperty", "visitQueryResult", "visitor", "result", "args", "runtimeDataModel", "modelName", "i", "visitResult", "visitNested", "includeOrSelect", "parentModelName", "fieldName", "subConfig", "isSkip", "field", "applyAllResultExtensions", "result", "modelName", "args", "extensions", "runtimeDataModel", "globalOmit", "visitQueryResult", "value", "dmmfModelName", "jsName", "dmmfToJSModelName", "applyResultExtensions", "Decimal", "ObjectEnumValue", "Sql", "denylist", "itxClientDenyList", "deepCloneArgs", "args", "Sql", "cloneSql", "isTypedSql", "cloneTypedSql", "clone", "i", "deepCloneValue", "k", "rawParam", "TypedSql", "x", "ObjectEnumValue", "isFieldRef", "isDecimalJsLike", "Decimal", "isDate", "copy", "assertNever", "iterateAndCallQueryCallbacks", "client", "params", "queryCbs", "i", "transaction", "prevCustomFetch", "deepCloneArgs", "args", "__internalParams", "currCustomFetch", "composeCustomDataProxyFetch", "applyQueryExtensions", "jsModelName", "action", "clientMethod", "operation", "cbs", "createApplyBatchExtensionsFunction", "executeBatch", "requests", "callbacks", "iterateAndCallBatchCallbacks", "prevFetch", "request", "_args", "nextFetch", "noopFetch", "f", "Decimal", "Decimal", "assertNever", "_", "message", "isDeepStrictEqual", "a", "b", "key", "doKeysMatch", "lhs", "rhs", "lhsKeys", "rhsKeys", "lhsDecimal", "asDecimal", "rhsDecimal", "lhsBuffer", "asBuffer", "rhsBuffer", "asDate", "asBigInt", "asNumber", "value", "safeJsonStringify", "obj", "_key", "val", "isTaggedValue", "value", "mapObjectValues", "object", "mapper", "result", "key", "deserializeJsonResponse", "isTaggedValue", "deserializeTaggedValue", "$type", "value", "buffer", "byteOffset", "byteLength", "Decimal", "assertNever", "isDriverAdapterError", "error", "ColumnTypeEnum", "UserFacingError", "message", "code", "meta", "rethrowAsUserFacing", "error", "isDriverAdapterError", "getErrorCode", "renderErrorMessage", "rethrowAsUserFacingRawError", "err", "assertNever", "address", "renderConstraint", "constraint", "field", "isPlaceholder", "value", "obj", "getPlaceholderName", "resolveArgPlaceholders", "args", "placeholderValues", "resolved", "key", "placeholderName", "convertCompactedRows", "rows", "compiledBatch", "keysPerRow", "item", "acc", "deserializeJsonResponse", "selection", "resolvedArgs", "rowIndex", "rowKeys", "doKeysMatch", "UserFacingError", "selected", "k", "Decimal", "DataMapperError", "UserFacingError", "message", "options", "fieldEntriesCache", "getFieldEntries", "fields", "entries", "applyDataMap", "data", "structure", "enums", "mapArrayOrObject", "mapValue", "assertNever", "skipNulls", "rows", "row", "mapObject", "decodedData", "error", "result", "name", "node", "serializedName", "nodeFields", "target", "dbName", "mapField", "value", "columnName", "fieldType", "v", "i", "scalarType", "numberValue", "parsedValue", "byte", "Decimal", "normalizeDateTime", "safeJsonStringify", "enumDef", "enumValue", "TIME_TZ_PATTERN", "dt", "timeTzMatches", "dtWithTz", "timeTz", "tz", "tzMinuteOffset", "timeSeparatorIndex", "klona", "x", "k", "tmp", "str", "val", "key", "formatSqlComment", "tags", "entries", "a", "b", "key", "value", "encodedKey", "encodedValue", "applySqlCommenters", "plugins", "context", "merged", "plugin", "klona", "buildSqlComment", "appendSqlComment", "sql", "comment", "SpanKind", "providerToOtelSystem", "provider", "assertNever", "withQuerySpanAndEvent", "query", "tracingHelper", "onQuery", "execute", "callback", "timestamp", "startInstant", "result", "endInstant", "SpanKind", "pad", "num", "size", "s", "os", "getHostname", "padding", "pid", "pad", "hostname", "length", "hostId", "prev", "char", "fingerprint", "isCuid", "value", "createCuid", "fingerprint", "discreteValues", "c", "randomBlock", "pad", "safeCounter", "cuid", "letter", "timestamp", "counter", "print", "random", "isCuid", "cuid", "createCuid", "fingerprint", "index_esm_default", "cuid", "import_cuid2", "crypto", "urlAlphabet", "POOL_SIZE_MULTIPLIER", "pool", "poolOffset", "fillPool", "bytes", "crypto", "nanoid", "size", "fillPool", "id", "i", "poolOffset", "urlAlphabet", "pool", "crypto", "ENCODING", "ENCODING_LEN", "RANDOM_LEN", "TIME_LEN", "TIME_MAX", "ULIDErrorCode", "ULIDError", "errorCode", "message", "randomChar", "prng", "rand", "ENCODING_LEN", "ENCODING", "detectPRNG", "root", "rootLookup", "detectRoot", "globalCrypto", "crypto", "buffer", "ULIDError", "ULIDErrorCode", "inWebWorker", "encodeRandom", "len", "prng", "str", "randomChar", "encodeTime", "now", "TIME_LEN", "TIME_MAX", "mod", "currentLen", "ENCODING_LEN", "ENCODING", "ulid", "seedTime", "prng", "currentPRNG", "detectPRNG", "seed", "encodeTime", "TIME_LEN", "encodeRandom", "RANDOM_LEN", "byteToHex", "i", "unsafeStringify", "arr", "offset", "randomFillSync", "rnds8Pool", "poolPtr", "rng", "randomUUID", "native_default", "v4", "options", "buf", "offset", "native_default", "rnds", "rng", "unsafeStringify", "v4_default", "_state", "v7", "options", "buf", "offset", "bytes", "v7Bytes", "rng", "now", "rnds", "updateV7State", "unsafeStringify", "state", "msecs", "seq", "v7_default", "GeneratorRegistry", "#generators", "UuidGenerator", "CuidGenerator", "UlidGenerator", "NanoIdGenerator", "ProductGenerator", "NowGenerator", "name", "generator", "#now", "arg", "v4_default", "v7_default", "index_esm_default", "cuid2", "ulid", "nanoid", "lhs", "rhs", "l", "r", "processRecords", "value", "ops", "processManyRecords", "processOneRecord", "record", "skip", "take", "cursor", "doKeysMatch", "processNestedRecords", "opsMap", "key", "records", "fields", "distinctBy", "paginate", "seen", "result", "getRecordKey", "pagination", "linkingFields", "paginateSingleList", "groupedByParent", "parentKey", "groupList", "aId", "bId", "elems", "list", "cursorIndex", "item", "start", "end", "field", "isPrismaValuePlaceholder", "value", "isPrismaValueGenerator", "renderQuery", "dbQuery", "scope", "generators", "maxChunkSize", "args", "arg", "evaluateArg", "renderRawSql", "chunkParams", "params", "UserFacingError", "renderTemplateSql", "assertNever", "doesRequireEvaluation", "isPrismaValuePlaceholder", "found", "isPrismaValueGenerator", "name", "generator", "el", "fragments", "placeholderFormat", "argTypes", "sql", "ctx", "flattenedParams", "flattenedArgTypes", "fragment", "pairFragmentsWithParams", "renderFragment", "length", "added", "flattenedFragmentParams", "i", "fragmentType", "formatPlaceholder", "tuple", "elements", "placeholderNumber", "param", "index", "value", "totalParamCount", "maxParamsPerFragment", "paramSize", "_", "chunkedParams", "thisParamCount", "chunks", "availableSize", "chunkArray", "chunk", "acc", "completeChunks", "currentChunk", "currentChunkParamCount", "array", "chunkSize", "result", "serializeSql", "resultSet", "row", "acc", "value", "index", "serializeRawSql", "type", "serializeColumnType", "serializeRawValue", "ColumnTypeEnum", "v", "columnType", "assertNever", "performValidation", "data", "rules", "error", "rule", "doesSatisfyRule", "message", "renderMessage", "code", "getErrorCode", "UserFacingError", "assertNever", "hint", "QueryInterpreter", "_QueryInterpreter", "#onQuery", "#generators", "GeneratorRegistry", "#tracingHelper", "#serializer", "#rawSerializer", "#provider", "#connectionInfo", "onQuery", "tracingHelper", "serializer", "rawSerializer", "provider", "connectionInfo", "options", "serializeSql", "serializeRawSql", "queryPlan", "value", "e", "rethrowAsUserFacing", "node", "context", "evaluateArg", "result", "arg", "nestedScope", "binding", "name", "isEmpty", "parts", "res", "acc", "part", "asList", "asNumber", "queries", "renderQuery", "#maxChunkSize", "sum", "query", "commentedQuery", "applyComments", "#withQuerySpanAndEvent", "err", "rethrowAsUserFacingRawError", "results", "lastInsertId", "mapField", "parent", "children", "joinExpr", "attachChildrenToParents", "transactionManager", "transactionInfo", "transaction", "applyDataMap", "performValidation", "doesSatisfyRule", "from", "to", "keyGetter", "item", "getRecordKey", "asRecord", "toSet", "processRecords", "record", "key", "initializer", "evalFieldInitializer", "entry", "evalFieldOperation", "assertNever", "#providerMaxChunkSize", "queryable", "execute", "withQuerySpanAndEvent", "field", "element", "parentRecords", "childRecords", "parentKeys", "k", "childKeys", "parentMap", "parentRecord", "childRecord", "scope", "generators", "op", "lhs", "rhs", "sqlCommenter", "comment", "buildSqlComment", "appendSqlComment", "getCrypto", "randomUUID", "once", "target", "event", "resolve", "TransactionManagerError", "UserFacingError", "message", "meta", "TransactionNotFoundError", "TransactionClosedError", "operation", "TransactionRolledBackError", "TransactionStartTimeoutError", "TransactionExecutionTimeoutError", "timeout", "timeTaken", "TransactionInternalConsistencyError", "InvalidTransactionIsolationLevelError", "isolationLevel", "MAX_CLOSED_TRANSACTIONS", "debug", "Debug", "COMMIT_QUERY", "ROLLBACK_QUERY", "PHANTOM_COMMIT_QUERY", "PHANTOM_ROLLBACK_QUERY", "TransactionManager", "#onQuery", "#provider", "driverAdapter", "transactionOptions", "tracingHelper", "onQuery", "provider", "options", "validatedOptions", "#validateOptions", "#startTransactionImpl", "transaction", "randomUUID", "abortController", "startTimer", "createTimeoutIfDefined", "startTransactionPromise", "rethrowAsUserFacing", "once", "tx", "e", "#closeTransaction", "TransactionStartTimeoutError", "#startTransactionTimeout", "TransactionInternalConsistencyError", "assertNever", "transactionId", "txw", "#getActiveOrClosingTransaction", "txInfo", "operation", "TransactionNotFoundError", "closedTransaction", "TransactionClosedError", "TransactionRolledBackError", "TransactionExecutionTimeoutError", "timeout", "timeoutStartedAt", "timer", "status", "createClosingPromise", "#withQuerySpanAndEvent", "query", "err", "fail", "TransactionManagerError", "InvalidTransactionIsolationLevelError", "queryable", "execute", "withQuerySpanAndEvent", "cb", "ms", "PrismaClientInitializationError", "PrismaClientKnownRequestError", "PrismaClientRustPanicError", "PrismaClientUnknownRequestError", "deserializeParamGraph", "serialized", "Deserializer", "decodeBase64url", "str", "Deserializer", "#serialized", "#view", "#offset", "serialized", "bytes", "decodeBase64url", "inputNodeCount", "outputNodeCount", "rootCount", "#readHeader", "inputNodes", "#readInputNodes", "outputNodes", "#readOutputNodes", "roots", "#readRoots", "#readVaruint", "value", "shift", "byte", "#readOptionalVaruint", "#readByte", "#readU16", "count", "i", "edgeCount", "edges", "j", "fieldIndex", "scalarMask", "childNodeId", "enumNameIndex", "edge", "argsNodeId", "outputNodeId", "keyIndex", "key", "root", "ParamGraph", "_ParamGraph", "#data", "#stringIndex", "#enumLookup", "data", "enumLookup", "i", "serialized", "deserializeParamGraph", "key", "entry", "id", "node", "fieldName", "nodeData", "fieldIndex", "edge", "enumName", "index", "EdgeFlag", "ScalarMask", "hasFlag", "flag", "getScalarMask", "version", "tagToArgScalarType", "deserializeRawParameters", "serializedParameters", "parsed", "err", "args", "parameter", "decodeParameter", "argTypes", "getArgType", "item", "getScalarType", "getBatchRequestPayload", "batch", "transaction", "maskQuery", "query", "substr", "normalizeLogs", "logs", "l", "import_new_github_issue_url", "getGitHubIssueUrl", "title", "user", "repo", "template", "body", "newGitHubIssueUrl", "getErrorMessageWithLink", "version", "binaryTarget", "title", "description", "engineVersion", "database", "query", "gotLogs", "getLogs", "logs", "normalizeLogs", "stripAnsi", "moreInfo", "body", "maskQuery", "url", "getGitHubIssueUrl", "underline", "LocalExecutor", "_LocalExecutor", "#options", "#driverAdapter", "#transactionManager", "#connectionInfo", "#interpreter", "options", "driverAdapter", "transactionManager", "QueryInterpreter", "TransactionManager", "error", "connectionInfo", "plan", "scope", "transaction", "batchIndex", "queryInfo", "queryable", "SCALAR_TAGS", "STRUCTURAL_TAGS", "classifyValue", "value", "obj", "tag", "isPlainObject", "isTaggedValue", "parameterizeQuery", "query", "view", "parameterizer", "Parameterizer", "rootKey", "root", "parameterizeBatch", "batch", "parameterizedQueries", "#view", "#placeholders", "#valueToPlaceholder", "#nextPlaceholderId", "#getOrCreatePlaceholder", "value", "type", "valueKey", "createValueKey", "existingName", "createPlaceholder", "name", "sel", "argsNodeId", "outNodeId", "argsNode", "outNode", "result", "#parameterizeObject", "#parameterizeSelection", "obj", "node", "key", "edge", "#parameterizeValue", "classified", "classifyValue", "#handlePrimitive", "#handleTaggedScalar", "#handleArray", "#handleObject", "hasFlag", "EdgeFlag", "mask", "getScalarMask", "getPrimitivePlaceholderType", "matchesPrimitiveMask", "ScalarMask", "tagged", "tag", "matchesTaggedMask", "getTaggedPlaceholderType", "decoded", "decodeTaggedValue", "items", "originalValue", "jsonValue", "enumValues", "item", "validateListElement", "decodedItems", "decodeIfTagged", "inferListElementType", "childNode", "isPlainObject", "selection", "nested", "childOutNode", "processedValue", "serializePlaceholderType", "serializeValue", "typeKey", "MAX_INT", "MIN_INT", "isTaggedValue", "QueryPlanCache", "#singleCache", "#batchCache", "#maxSize", "maxSize", "key", "entry", "plan", "firstKey", "response", "PrismaClientKnownRequestError", "fieldContentRegExp", "serialize", "name", "value", "options", "opt", "enc", "encodedValue", "str", "maxAge", "isDate", "val", "parseSetCookie", "setCookieValue", "parts", "nameValuePairStr", "parsed", "_parseNameValuePair", "cookie", "part", "sides", "partKey", "partValue", "nameValueArr", "PrismaClientError", "message", "info", "AccelerateError", "PrismaClientError", "message", "info", "setRetryable", "info", "retryable", "InvalidDatasourceError", "AccelerateError", "message", "info", "setRetryable", "setClassName", "getUrlAndApiKey", "options", "errorInfo", "url", "err", "message", "InvalidDatasourceError", "protocol", "searchParams", "PRISMA_POSTGRES_PROTOCOL", "apiKey", "httpScheme", "isPrismaPostgresDev", "httpUrl", "import_engines_version", "HeaderBuilder", "apiKey", "tracingHelper", "logLevel", "logQueries", "engineHash", "traceparent", "transactionId", "headers", "captureTelemetry", "#buildCaptureSettings", "convertEngineTimestamp", "timestamp", "dateFromEngineTimestamp", "debug", "Debug", "RemoteExecutor", "#clientVersion", "#headerBuilder", "#httpClient", "#logEmitter", "#tracingHelper", "#sqlCommenters", "options", "url", "apiKey", "getUrlAndApiKey", "HttpClient", "HeaderBuilder", "#request", "plan", "placeholderValues", "batchIndex", "model", "operation", "transaction", "customFetch", "queryInfo", "comments", "applySqlCommenters", "path", "method", "body", "fetch", "batchRequestIdx", "response", "#throwErrorFromResponse", "responseJson", "#processExtensions", "errorCode", "responseText", "errorJson", "errorMessage", "errorMeta", "PrismaClientKnownRequestError", "extensions", "log", "#emitLogEvent", "event", "dateFromEngineTimestamp", "#baseUrl", "#cookieJar", "#machineHint", "baseUrl", "headers", "requestUrl", "cookieHeader", "#getCookieHeader", "#storeCookiesFromResponse", "validCookies", "now", "key", "cookie", "domain", "serialize", "setCookieHeaders", "setCookieHeader", "cookieString", "parseSetCookie", "PrismaClientInitializationError", "loadedWasmInstances", "wasmQueryCompilerLoader", "config", "clientVersion", "compilerWasm", "loading", "runtime", "wasmModule", "options", "instance", "wbindgen_start", "CLIENT_ENGINE_ERROR", "debug", "Debug", "globalWithPanicHandler", "message", "PrismaClientRustPanicError", "version", "ClientEngine", "#QueryCompilerConstructor", "#state", "#queryCompilerLoader", "#executorKind", "#queryPlanCache", "#queryPlanCacheEnabled", "#paramGraph", "#emitQueryEvent", "config", "queryCompilerLoader", "PrismaClientInitializationError", "wasmQueryCompilerLoader", "QueryPlanCache", "ParamGraph", "enumName", "v", "event", "safeJsonStringify", "#ensureStarted", "connecting", "executor", "queryCompiler", "#connectExecutor", "#instantiateQueryCompiler", "error", "engine", "RemoteExecutor", "LocalExecutor", "#convertIsolationLevel", "QueryCompilerConstructor", "provider", "connectionInfo", "#withLocalPanicHandler", "e", "#transformInitError", "err", "#transformRequestError", "query", "getErrorMessageWithLink", "UserFacingError", "PrismaClientKnownRequestError", "PrismaClientUnknownRequestError", "#transformCompileError", "fn", "disconnectOnPanic", "previousHandler", "panic", "disconnecting", "action", "_headers", "arg", "result", "options", "txInfo", "assertNever", "interactiveTransaction", "customDataProxyFetch", "plan", "placeholderValues", "isRawQuery", "compileRawQuery", "parameterizedQuery", "extractedValues", "parameterizeQuery", "cacheKey", "cached", "#compileQuery", "queries", "transaction", "firstAction", "firstModelName", "batchPayload", "getBatchRequestPayload", "request", "hasRawQueries", "batchResponse", "parameterizedBatch", "parameterizeBatch", "cacheKeyStr", "#compileBatch", "txOptions", "results", "rollback", "batchIndex", "rows", "q", "actions", "modelNames", "convertCompactedRows", "compiler", "#withCompileSpan", "clientIsolationLevel", "execute", "m", "title", "sql", "args", "argTypes", "deserializeRawParameters", "getEngineInstance", "engineConfig", "ClientEngine", "rawCommandArgsMapper", "command", "Sql", "mssqlPreparedStatement", "sql", "acc", "str", "idx", "Decimal", "serializeRawParameters", "parameters", "serializeRawParametersInternal", "objectSerialization", "parameter", "encodeParameter", "item", "isDate", "Decimal", "isArrayBufferLike", "buffer", "byteOffset", "byteLength", "preprocessObject", "value", "obj", "preprocessValueInObject", "result", "key", "ALTER_RE", "debug", "Debug", "checkAlter", "activeProvider", "query", "values", "invalidCall", "rawQueryArgsMapper", "clientMethod", "args", "queryString", "parameters", "isTypedSql", "serializeRawParameters", "mssqlPreparedStatement", "templateStringMiddlewareArgsMapper", "sql", "requestArgs", "strings", "Sql", "sqlMiddlewareArgsMapper", "createPrismaPromiseFactory", "transaction", "callback", "op", "promise", "_callback", "callbackTransaction", "valueToPromise", "error", "onFulfilled", "onRejected", "onFinally", "batchTransaction", "thing", "package_default", "majorVersion", "package_default", "GLOBAL_INSTRUMENTATION_KEY", "GLOBAL_VERSIONED_INSTRUMENTATION_KEY", "globalThisWithPrismaInstrumentation", "getGlobalTracingHelper", "versionedGlobal", "disabledTracingHelper", "options", "callback", "DynamicTracingHelper", "context", "spans", "getGlobalTracingHelper", "getTracingHelper", "getLockCountPromise", "knock", "cb", "resolve", "lock", "res", "onFulfilled", "getLogLevel", "log", "acc", "curr", "currentLevel", "hasBatchIndex", "getBatchId", "query", "parts", "buildKeysString", "obj", "key", "value", "writeMap", "isWrite", "action", "DataLoader", "options", "request", "hash", "resolve", "reject", "key", "batch", "result", "e", "a", "b", "j", "results", "value", "Decimal", "deserializeValue", "type", "value", "buffer", "byteOffset", "byteLength", "v", "deserializeRawResult", "response", "deserializedResponse", "prebuiltEmptyObject", "createPrebuiltEmptyResultObject", "i", "row", "mappedRow", "j", "debug", "Debug", "RequestHandler", "client", "logEmitter", "DataLoader", "createApplyBatchExtensionsFunction", "requests", "customDataProxyFetch", "transaction", "otelParentCtx", "queries", "r", "traceparent", "containsWrite", "isWrite", "getTransactionOptions", "result", "i", "error", "request", "interactiveTransaction", "getItxTransactionOptions", "response", "getBatchId", "requestA", "requestB", "params", "clientMethod", "callsite", "args", "modelName", "dataPath", "unpacker", "data", "err", "globalOmit", "isMismatchingBatchIndex", "PrismaClientKnownRequestError", "isValidationError", "validationError", "convertValidationError", "throwValidationException", "message", "createErrorMessageWithContext", "meta", "PrismaClientRustPanicError", "PrismaClientUnknownRequestError", "PrismaClientInitializationError", "stripAnsi", "operation", "pathForGet", "key", "extractedResponse", "deepGet", "deserializedResponse", "deserializeRawResult", "deserializeJsonResponse", "assertNever", "hasBatchIndex", "selectionPath", "clientVersion", "version", "import_js_levenshtein", "PrismaClientConstructorValidationError", "message", "setClassName", "knownProperties", "errorFormats", "logLevels", "validators", "accelerateUrl", "PrismaClientConstructorValidationError", "options", "didYouMean", "getDidYouMean", "validateLogLevel", "level", "option", "logValidators", "value", "emits", "key", "maxWait", "timeout", "config", "validationErrors", "modelKey", "modelConfig", "modelOrType", "getModelOrTypeByKey", "fieldName", "field", "renderOmitValidationErrors", "i", "knownKeys", "validateDependentOptions", "adapterProvided", "accelerateUrlProvided", "validatePrismaClientOptions", "str", "alternative", "getAlternative", "optionsWithDistances", "leven", "a", "b", "bestAlternative", "runtimeDataModel", "findByKey", "map", "foundKey", "mapKey", "uncapitalize", "omitConfig", "argsTree", "buildArgumentsRenderingTree", "error", "message", "args", "renderArgsTree", "hasBatchIndex", "waitForBatch", "promises", "resolve", "reject", "successfulResults", "bestError", "done", "settledPromisesCount", "settleOnePromise", "immediatelyReject", "error", "i", "result", "debug", "Debug", "noopMiddlewareArgsMapper", "param", "TX_ID", "BatchTxIdCounter", "getPrismaClient", "config", "PrismaClient", "createPrismaPromiseFactory", "optionsArg", "PrismaClientInitializationError", "clientVersion", "validatePrismaClientOptions", "logEmitter", "EventEmitter", "MergedExtensionsList", "getTracingHelper", "adapter", "expectedDriverAdapterProvider", "options", "useDebug", "getLogLevel", "o", "getEngineInstance", "RequestHandler", "log", "level", "event", "logger_exports", "e", "applyModelsAndClientExtensions", "eventType", "callback", "clearLogs", "transaction", "clientMethod", "args", "middlewareArgsMapper", "activeProvider", "rawQueryArgsMapper", "getCallSite", "query", "values", "sql", "argsMapper", "toSql", "checkAlter", "PrismaClientValidationError", "command", "rawCommandArgsMapper", "typedSql", "promises", "id", "lock", "getLockCountPromise", "requests", "request", "index", "isolationLevel", "waitForBatch", "headers", "optionsWithDefaults", "info", "result", "createCompositeProxy", "unApplyModelsAndClientExtensions", "addProperty", "removeProperties", "itxClientDenyList", "input", "spanOptions", "internalParams", "params", "consumer", "changedMiddlewareParams", "runInTransaction", "changedRequestParams", "requestParams", "applyQueryExtensions", "applyAllResultExtensions", "AsyncResource", "dataPath", "callsite", "action", "model", "unpacker", "otelParentCtx", "customDataProxyFetch", "message", "serializeJsonQuery", "prettyPrintArguments", "feature", "$extends", "isTemplateStringArray", "Sql", "templateStringMiddlewareArgsMapper", "sqlMiddlewareArgsMapper", "value", "allowList", "makeStrictEnum", "definition", "target", "property", "isNode", "isBun", "isDeno", "isNetlify", "isEdgeLight", "isWorkerd", "detectRuntime", "check", "runtimesPrettyNames", "getRuntime", "runtimeId", "PrismaClientInitializationError", "PrismaClientKnownRequestError", "PrismaClientRustPanicError", "PrismaClientUnknownRequestError", "PrismaClientValidationError", "empty", "join", "raw", "Sql", "sql", "AnyNull", "DbNull", "isAnyNull", "isDbNull", "isJsonNull", "JsonNull", "NullTypes", "ObjectEnumValue", "Decimal"]
|
|
7
7
|
}
|