10 lines
32 KiB
JavaScript
10 lines
32 KiB
JavaScript
import * as ___react___ from 'react';
|
|
import * as ___react_dom___ from 'react-dom';
|
|
|
|
function require(mod) {
|
|
if (mod === 'react') return ___react___;
|
|
if (mod === 'react-dom') return ___react_dom___;
|
|
throw new Error(`Unknown module ${mod}`);
|
|
}
|
|
var w=new WeakMap;function k(e){let r=w.get(e);return r==null?null:(w.delete(e),r)}function g(e){let{abortSignal:r,durationMs:t}=e;r&&w.set(r,t)}function F(e){if(typeof performance.getEntriesByType!="function")return null;let r=performance.getEntriesByType("resource"),t=b(e.requestUrl),o=null,l=Number.POSITIVE_INFINITY;for(let d of r){let s=d;if(s.initiatorType!=="fetch"||!x(t,s.name,e.requestUrl)||s.startTime+1<e.requestStartedAt)continue;let u=Math.abs(s.startTime-e.requestStartedAt);u>l||(l=u,o=Math.round(s.duration))}return o}function b(e){try{let r=new URL(e);return{origin:r.origin,pathname:R(r.pathname)}}catch{return null}}function x(e,r,t){if(!e)return r===t;try{let o=new URL(r);return o.origin===e.origin&&R(o.pathname)===e.pathname}catch{return!1}}function R(e){return e.endsWith("/")&&e.length>1?e.slice(0,-1):e}async function y(e){let r=F({requestStartedAt:e.requestStartedAt,requestUrl:e.responseUrl});if(r!=null)return r;await new Promise(o=>{setTimeout(o,0)});let t=F({requestStartedAt:e.requestStartedAt,requestUrl:e.responseUrl});return t??Math.round(performance.now()-e.requestStartedAt)}function B(e){let{customHeaders:r,customPayload:t,resultDeserializerFn:o,url:l}=e,d=e.fetch||fetch;return{async execute(s,u){try{let i=performance.now(),n=await d(l,{body:JSON.stringify({customPayload:t,procedure:"query",query:s}),headers:{Accept:"application/json","Content-Type":"application/json",...r},method:"POST",signal:u?.abortSignal}),f=await y({requestStartedAt:i,responseUrl:n.url});if(g({abortSignal:u?.abortSignal,durationMs:f}),!n.ok){let c;try{c=await n.text()}catch{c="unknown error"}return[new Error(c)]}let[a,S]=await n.json();return a?[m(a)]:[null,o?.(S)||S]}catch(i){return[i]}},async executeSequence(s,u){try{let i=performance.now(),n=await d(l,{body:JSON.stringify({customPayload:t,procedure:"sequence",sequence:s}),headers:{Accept:"application/json","Content-Type":"application/json",...r},method:"POST",signal:u?.abortSignal}),f=await y({requestStartedAt:i,responseUrl:n.url});if(g({abortSignal:u?.abortSignal,durationMs:f}),!n.ok){let q;try{q=await n.text()}catch{q="unknown error"}return[[new Error(q)]]}let[[a,S],c]=await n.json();if(a)return[[m(a)]];let p=o?.(S)||S,[h,E]=c||[];return h?[[null,p],[m(h)]]:[[null,p],[null,o?.(E)||E]]}catch(i){return[[i]]}},async executeTransaction(s,u){try{let i=performance.now(),n=await d(l,{body:JSON.stringify({customPayload:t,procedure:"transaction",queries:s}),headers:{Accept:"application/json","Content-Type":"application/json",...r},method:"POST",signal:u?.abortSignal}),f=await y({requestStartedAt:i,responseUrl:n.url});if(g({abortSignal:u?.abortSignal,durationMs:f}),!n.ok){let p;try{p=await n.text()}catch{p="unknown error"}return[new Error(p)]}let[a,S]=await n.json();return a?[m(a)]:[null,(S??[]).map(p=>o?.(p)||p)]}catch(i){return[i]}},async lintSql(s,u){try{let i=performance.now(),n=await d(l,{body:JSON.stringify({customPayload:t,procedure:"sql-lint",schemaVersion:s.schemaVersion,sql:s.sql}),headers:{Accept:"application/json","Content-Type":"application/json",...r},method:"POST",signal:u?.abortSignal}),f=await y({requestStartedAt:i,responseUrl:n.url});if(g({abortSignal:u?.abortSignal,durationMs:f}),!n.ok){let c;try{c=await n.text()}catch{c="unknown error"}return[new Error(c)]}let[a,S]=await n.json();return a?[m(a)]:[null,S]}catch(i){return[i]}}}}function T(e){if(e instanceof AggregateError){let{name:r,message:t}=e,o=e.errors.map(T);return{name:r,message:t,errors:o}}if(e instanceof Error){let{name:r,message:t}=e;return{name:r,message:t}}return{name:"UnknownError",message:JSON.stringify(e)}}function m(e){let{name:r,message:t}=e;if(e.errors!==void 0){let l=e.errors.map(m),d=new AggregateError(l,t);return d.name=e.name,d}let o=new Error(e.message);return e.name=r,o}export{k as a,B as b,T as c,m as d};
|
|
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../data/bff/bff-client.ts"],
  "sourcesContent": ["import type { AdapterSqlLintDiagnostic } from \"../adapter\";\nimport type { ExecuteOptions, SequenceExecutor } from \"../executor\";\nimport type { Query, QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\n\nconst bffRequestDurationByAbortSignal = new WeakMap<AbortSignal, number>();\n\nexport function consumeBffRequestDurationMsForSignal(\n  abortSignal: AbortSignal,\n): number | null {\n  const duration = bffRequestDurationByAbortSignal.get(abortSignal);\n\n  if (duration == null) {\n    return null;\n  }\n\n  bffRequestDurationByAbortSignal.delete(abortSignal);\n  return duration;\n}\n\nfunction recordBffRequestDuration(args: {\n  abortSignal: AbortSignal | undefined;\n  durationMs: number;\n}): void {\n  const { abortSignal, durationMs } = args;\n\n  if (!abortSignal) {\n    return;\n  }\n\n  bffRequestDurationByAbortSignal.set(abortSignal, durationMs);\n}\n\nfunction getBffNetworkDurationMs(args: {\n  requestStartedAt: number;\n  requestUrl: string;\n}): number | null {\n  if (typeof performance.getEntriesByType !== \"function\") {\n    return null;\n  }\n\n  const entries = performance.getEntriesByType(\n    \"resource\",\n  ) as PerformanceEntry[];\n  const normalizedRequestUrl = normalizeComparableResourceUrl(args.requestUrl);\n\n  let bestDurationMs: number | null = null;\n  let bestStartDelta = Number.POSITIVE_INFINITY;\n\n  for (const entry of entries) {\n    const fetchEntry = entry as PerformanceResourceTiming;\n\n    if (fetchEntry.initiatorType !== \"fetch\") {\n      continue;\n    }\n\n    if (\n      !matchesComparableResourceUrl(\n        normalizedRequestUrl,\n        fetchEntry.name,\n        args.requestUrl,\n      )\n    ) {\n      continue;\n    }\n\n    if (fetchEntry.startTime + 1 < args.requestStartedAt) {\n      continue;\n    }\n\n    const startDelta = Math.abs(fetchEntry.startTime - args.requestStartedAt);\n\n    if (startDelta > bestStartDelta) {\n      continue;\n    }\n\n    bestStartDelta = startDelta;\n    bestDurationMs = Math.round(fetchEntry.duration);\n  }\n\n  return bestDurationMs;\n}\n\nfunction normalizeComparableResourceUrl(url: string): {\n  origin: string;\n  pathname: string;\n} | null {\n  try {\n    const normalizedUrl = new URL(url);\n\n    return {\n      origin: normalizedUrl.origin,\n      pathname: trimTrailingSlash(normalizedUrl.pathname),\n    };\n  } catch {\n    return null;\n  }\n}\n\nfunction matchesComparableResourceUrl(\n  normalizedRequestUrl: {\n    origin: string;\n    pathname: string;\n  } | null,\n  candidateUrl: string,\n  fallbackRequestUrl: string,\n): boolean {\n  if (!normalizedRequestUrl) {\n    return candidateUrl === fallbackRequestUrl;\n  }\n\n  try {\n    const normalizedCandidateUrl = new URL(candidateUrl);\n\n    return (\n      normalizedCandidateUrl.origin === normalizedRequestUrl.origin &&\n      trimTrailingSlash(normalizedCandidateUrl.pathname) ===\n        normalizedRequestUrl.pathname\n    );\n  } catch {\n    return false;\n  }\n}\n\nfunction trimTrailingSlash(pathname: string): string {\n  if (pathname.endsWith(\"/\") && pathname.length > 1) {\n    return pathname.slice(0, -1);\n  }\n\n  return pathname;\n}\n\nasync function getBffRequestDurationMs(args: {\n  requestStartedAt: number;\n  responseUrl: string;\n}): Promise<number> {\n  const immediateDurationMs = getBffNetworkDurationMs({\n    requestStartedAt: args.requestStartedAt,\n    requestUrl: args.responseUrl,\n  });\n\n  if (immediateDurationMs != null) {\n    return immediateDurationMs;\n  }\n\n  await new Promise<void>((resolve) => {\n    setTimeout(resolve, 0);\n  });\n\n  const delayedDurationMs = getBffNetworkDurationMs({\n    requestStartedAt: args.requestStartedAt,\n    requestUrl: args.responseUrl,\n  });\n\n  if (delayedDurationMs != null) {\n    return delayedDurationMs;\n  }\n\n  return Math.round(performance.now() - args.requestStartedAt);\n}\n\nexport interface StudioBFFClientProps {\n  /**\n   * Allows passing custom headers to the BFF.\n   *\n   * e.g. authorization token.\n   */\n  customHeaders?: Record<string, string>;\n\n  /**\n   * Allows passing custom payload to the BFF via `body.customPayload`.\n   *\n   * e.g. tenant id.\n   */\n  customPayload?: Record<string, unknown>;\n\n  /**\n   * Allows overriding the fetch function implementation.\n   *\n   * e.g. for testing, or older Node.js versions.\n   */\n  fetch?: typeof globalThis.fetch;\n\n  /**\n   * Function used to deserialize the results of queries.\n   *\n   * By default, the results are returned as is without any additional processing.\n   */\n  resultDeserializerFn?(this: void, results: unknown): unknown[];\n\n  /**\n   * BFF endpoint URL.\n   *\n   * e.g. `https://api.example.com/studio`\n   */\n  url: string | URL;\n}\n\nexport interface StudioBFFClient extends SequenceExecutor {\n  /**\n   * Requests BFF to query the database.\n   *\n   * The query is sent as `body.query`.\n   */\n  execute<T>(\n    this: void,\n    query: Query<T>,\n    options?: ExecuteOptions,\n  ): Promise<Either<Error, QueryResult<Query<T>>>>;\n\n  /**\n   * Requests BFF to execute a sequence of queries.\n   *\n   * The sequence is sent as `body.sequence`.\n   */\n  executeSequence<T, S>(\n    this: void,\n    sequence: readonly [Query<T>, Query<S>],\n    options?: ExecuteOptions,\n  ): Promise<\n    | [[Error]]\n    | [[null, QueryResult<Query<T>>], Either<Error, QueryResult<Query<S>>>]\n  >;\n\n  /**\n   * Requests BFF to execute a transactional batch of queries.\n   *\n   * The queries are sent as `body.queries`.\n   */\n  executeTransaction(\n    this: void,\n    queries: readonly Query<unknown>[],\n    options?: ExecuteOptions,\n  ): Promise<Either<Error, QueryResult<Query<unknown>>[]>>;\n\n  /**\n   * Requests BFF to lint SQL via parse/plan diagnostics.\n   */\n  lintSql(\n    this: void,\n    details: StudioBFFSqlLintDetails,\n    options?: ExecuteOptions,\n  ): Promise<Either<Error, StudioBFFSqlLintResult>>;\n}\n\nexport type StudioBFFRequest =\n  | StudioBFFQueryRequest\n  | StudioBFFSequenceRequest\n  | StudioBFFTransactionRequest\n  | StudioBFFSqlLintRequest;\n\nexport interface StudioBFFQueryRequest {\n  customPayload?: Record<string, unknown>;\n  procedure: \"query\";\n  query: Query<unknown>;\n}\n\nexport interface StudioBFFSequenceRequest {\n  customPayload?: Record<string, unknown>;\n  procedure: \"sequence\";\n  sequence: readonly [Query<unknown>, Query<unknown>];\n}\n\nexport interface StudioBFFTransactionRequest {\n  customPayload?: Record<string, unknown>;\n  procedure: \"transaction\";\n  queries: readonly Query<unknown>[];\n}\n\nexport interface StudioBFFSqlLintDetails {\n  schemaVersion?: string;\n  sql: string;\n}\n\nexport interface StudioBFFSqlLintResult {\n  diagnostics: AdapterSqlLintDiagnostic[];\n  schemaVersion?: string;\n}\n\nexport interface StudioBFFSqlLintRequest {\n  customPayload?: Record<string, unknown>;\n  procedure: \"sql-lint\";\n  schemaVersion?: string;\n  sql: string;\n}\n\n/**\n * Creates a Studio BFF client. BFF stands for \"Backend For Frontend\" btw.\n */\nexport function createStudioBFFClient(\n  props: StudioBFFClientProps,\n): StudioBFFClient {\n  const { customHeaders, customPayload, resultDeserializerFn, url } = props;\n  const fetchFn = props.fetch || fetch;\n\n  return {\n    async execute(query, options) {\n      try {\n        const requestStartedAt = performance.now();\n        const response = await fetchFn(url, {\n          body: JSON.stringify({\n            customPayload,\n            procedure: \"query\",\n            query,\n          } satisfies StudioBFFQueryRequest),\n          headers: {\n            Accept: \"application/json\",\n            \"Content-Type\": \"application/json\",\n            ...customHeaders,\n          },\n          method: \"POST\",\n          signal: options?.abortSignal,\n        });\n        const requestDurationMs = await getBffRequestDurationMs({\n          requestStartedAt,\n          responseUrl: response.url,\n        });\n        recordBffRequestDuration({\n          abortSignal: options?.abortSignal,\n          durationMs: requestDurationMs,\n        });\n\n        if (!response.ok) {\n          let errorText: string;\n\n          try {\n            errorText = await response.text();\n          } catch {\n            errorText = \"unknown error\";\n          }\n\n          return [new Error(errorText)];\n        }\n\n        const [error, results] = (await response.json()) as [\n          SerializedError,\n          unknown,\n        ];\n\n        if (error) {\n          return [deserializeError(error)];\n        }\n\n        return [null, (resultDeserializerFn?.(results) || results) as never];\n      } catch (error: unknown) {\n        return [error as Error];\n      }\n    },\n\n    async executeSequence(sequence, options) {\n      try {\n        const requestStartedAt = performance.now();\n        const response = await fetchFn(url, {\n          body: JSON.stringify({\n            customPayload,\n            procedure: \"sequence\",\n            sequence,\n          } satisfies StudioBFFSequenceRequest),\n          headers: {\n            Accept: \"application/json\",\n            \"Content-Type\": \"application/json\",\n            ...customHeaders,\n          },\n          method: \"POST\",\n          signal: options?.abortSignal,\n        });\n        const requestDurationMs = await getBffRequestDurationMs({\n          requestStartedAt,\n          responseUrl: response.url,\n        });\n        recordBffRequestDuration({\n          abortSignal: options?.abortSignal,\n          durationMs: requestDurationMs,\n        });\n\n        if (!response.ok) {\n          let errorText: string;\n\n          try {\n            errorText = await response.text();\n          } catch {\n            errorText = \"unknown error\";\n          }\n\n          return [[new Error(errorText)]];\n        }\n\n        const [[firstError, firstResult], maybeSecondResult] =\n          (await response.json()) as [\n            [SerializedError, unknown],\n            ...[SerializedError, unknown][],\n          ];\n\n        if (firstError) {\n          return [[deserializeError(firstError)]];\n        }\n\n        const firstDeserializedResult = (resultDeserializerFn?.(firstResult) ||\n          firstResult) as never;\n\n        const [secondError, secondResult] = maybeSecondResult || [];\n\n        if (secondError) {\n          return [\n            [null, firstDeserializedResult],\n            [deserializeError(secondError)],\n          ];\n        }\n\n        return [\n          [null, firstDeserializedResult],\n          [\n            null,\n            (resultDeserializerFn?.(secondResult) || secondResult) as never,\n          ],\n        ];\n      } catch (error: unknown) {\n        return [[error as Error]];\n      }\n    },\n\n    async executeTransaction(queries, options) {\n      try {\n        const requestStartedAt = performance.now();\n        const response = await fetchFn(url, {\n          body: JSON.stringify({\n            customPayload,\n            procedure: \"transaction\",\n            queries,\n          } satisfies StudioBFFTransactionRequest),\n          headers: {\n            Accept: \"application/json\",\n            \"Content-Type\": \"application/json\",\n            ...customHeaders,\n          },\n          method: \"POST\",\n          signal: options?.abortSignal,\n        });\n        const requestDurationMs = await getBffRequestDurationMs({\n          requestStartedAt,\n          responseUrl: response.url,\n        });\n        recordBffRequestDuration({\n          abortSignal: options?.abortSignal,\n          durationMs: requestDurationMs,\n        });\n\n        if (!response.ok) {\n          let errorText: string;\n\n          try {\n            errorText = await response.text();\n          } catch {\n            errorText = \"unknown error\";\n          }\n\n          return [new Error(errorText)];\n        }\n\n        const [error, results] = (await response.json()) as [\n          SerializedError,\n          unknown[],\n        ];\n\n        if (error) {\n          return [deserializeError(error)];\n        }\n\n        const deserializedResults = (results ?? []).map((result) =>\n          (resultDeserializerFn?.(result) || result) as never,\n        );\n\n        return [null, deserializedResults];\n      } catch (error: unknown) {\n        return [error as Error];\n      }\n    },\n\n    async lintSql(details, options) {\n      try {\n        const requestStartedAt = performance.now();\n        const response = await fetchFn(url, {\n          body: JSON.stringify({\n            customPayload,\n            procedure: \"sql-lint\",\n            schemaVersion: details.schemaVersion,\n            sql: details.sql,\n          } satisfies StudioBFFSqlLintRequest),\n          headers: {\n            Accept: \"application/json\",\n            \"Content-Type\": \"application/json\",\n            ...customHeaders,\n          },\n          method: \"POST\",\n          signal: options?.abortSignal,\n        });\n        const requestDurationMs = await getBffRequestDurationMs({\n          requestStartedAt,\n          responseUrl: response.url,\n        });\n        recordBffRequestDuration({\n          abortSignal: options?.abortSignal,\n          durationMs: requestDurationMs,\n        });\n\n        if (!response.ok) {\n          let errorText: string;\n\n          try {\n            errorText = await response.text();\n          } catch {\n            errorText = \"unknown error\";\n          }\n\n          return [new Error(errorText)];\n        }\n\n        const [error, result] = (await response.json()) as [\n          SerializedError,\n          StudioBFFSqlLintResult,\n        ];\n\n        if (error) {\n          return [deserializeError(error)];\n        }\n\n        return [null, result];\n      } catch (error: unknown) {\n        return [error as Error];\n      }\n    },\n  };\n}\n\nexport interface SerializedError {\n  message: string;\n  name: string;\n  errors?: SerializedError[];\n}\n\nexport function serializeError(error: unknown): SerializedError {\n  if (error instanceof AggregateError) {\n    const { name, message } = error;\n    const errors = error.errors.map(serializeError);\n    return { name, message, errors };\n  }\n\n  if (error instanceof Error) {\n    const { name, message } = error;\n    return { name, message };\n  }\n\n  return { name: `UnknownError`, message: JSON.stringify(error) };\n}\n\nexport function deserializeError(error: SerializedError): Error {\n  const { name, message } = error;\n\n  if (error.errors !== undefined) {\n    const errors = error.errors.map(deserializeError);\n    const aggregateError = new AggregateError(errors, message);\n    aggregateError.name = error.name;\n    return aggregateError;\n  }\n\n  const regularError = new Error(error.message);\n  error.name = name;\n  return regularError;\n}\n"],
  "mappings": "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",
  "names": ["bffRequestDurationByAbortSignal", "consumeBffRequestDurationMsForSignal", "abortSignal", "duration", "recordBffRequestDuration", "args", "durationMs", "getBffNetworkDurationMs", "entries", "normalizedRequestUrl", "normalizeComparableResourceUrl", "bestDurationMs", "bestStartDelta", "entry", "fetchEntry", "matchesComparableResourceUrl", "startDelta", "url", "normalizedUrl", "trimTrailingSlash", "candidateUrl", "fallbackRequestUrl", "normalizedCandidateUrl", "pathname", "getBffRequestDurationMs", "immediateDurationMs", "resolve", "delayedDurationMs", "createStudioBFFClient", "props", "customHeaders", "customPayload", "resultDeserializerFn", "fetchFn", "query", "options", "requestStartedAt", "response", "requestDurationMs", "errorText", "error", "results", "deserializeError", "sequence", "firstError", "firstResult", "maybeSecondResult", "firstDeserializedResult", "secondError", "secondResult", "queries", "result", "details", "serializeError", "name", "message", "errors", "aggregateError", "regularError"]
}

|