@sanity/client 6.9.0 → 6.9.1
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/dist/_chunks/{browserMiddleware-qjpIf6pt.js → browserMiddleware-MafB5TmI.js} +1 -4
- package/dist/_chunks/browserMiddleware-MafB5TmI.js.map +1 -0
- package/dist/_chunks/{browserMiddleware-QFfeiNj_.cjs → browserMiddleware-yPyURfGu.cjs} +1 -4
- package/dist/_chunks/browserMiddleware-yPyURfGu.cjs.map +1 -0
- package/dist/_chunks/{nodeMiddleware-FR4SCkjH.js → nodeMiddleware-_IDbqRDk.js} +2 -5
- package/dist/_chunks/nodeMiddleware-_IDbqRDk.js.map +1 -0
- package/dist/_chunks/{nodeMiddleware-1sT0QRFz.cjs → nodeMiddleware-xi7HzSDh.cjs} +2 -5
- package/dist/_chunks/nodeMiddleware-xi7HzSDh.cjs.map +1 -0
- package/dist/index.browser.cjs +1 -1
- package/dist/index.browser.js +2 -2
- package/dist/index.cjs +1 -1
- package/dist/index.js +2 -2
- package/dist/stega.browser.cjs +7 -28
- package/dist/stega.browser.cjs.map +1 -1
- package/dist/stega.browser.js +8 -29
- package/dist/stega.browser.js.map +1 -1
- package/dist/stega.cjs +7 -28
- package/dist/stega.cjs.map +1 -1
- package/dist/stega.d.ts +4 -12
- package/dist/stega.js +8 -29
- package/dist/stega.js.map +1 -1
- package/package.json +1 -1
- package/src/data/dataMethods.ts +0 -5
- package/src/stega/SanityStegaClient.ts +12 -34
- package/src/stega/config.ts +1 -22
- package/umd/sanityClient.js +0 -3
- package/umd/sanityClient.min.js +3 -3
- package/dist/_chunks/browserMiddleware-QFfeiNj_.cjs.map +0 -1
- package/dist/_chunks/browserMiddleware-qjpIf6pt.js.map +0 -1
- package/dist/_chunks/nodeMiddleware-1sT0QRFz.cjs.map +0 -1
- package/dist/_chunks/nodeMiddleware-FR4SCkjH.js.map +0 -1
package/dist/stega.d.ts
CHANGED
|
@@ -1628,9 +1628,7 @@ export declare class ObservableSanityStegaClient extends ObservableSanityClient
|
|
|
1628
1628
|
fetch<R = Any, Q = QueryParams>(
|
|
1629
1629
|
query: string,
|
|
1630
1630
|
params: Q | undefined,
|
|
1631
|
-
options: FilteredResponseQueryOptions
|
|
1632
|
-
stega?: boolean | StegaConfig
|
|
1633
|
-
},
|
|
1631
|
+
options: FilteredResponseQueryOptions,
|
|
1634
1632
|
): Observable<R>
|
|
1635
1633
|
/**
|
|
1636
1634
|
* Perform a GROQ-query against the configured dataset.
|
|
@@ -1642,9 +1640,7 @@ export declare class ObservableSanityStegaClient extends ObservableSanityClient
|
|
|
1642
1640
|
fetch<R = Any, Q = QueryParams>(
|
|
1643
1641
|
query: string,
|
|
1644
1642
|
params: Q | undefined,
|
|
1645
|
-
options: UnfilteredResponseQueryOptions
|
|
1646
|
-
stega?: boolean | StegaConfig
|
|
1647
|
-
},
|
|
1643
|
+
options: UnfilteredResponseQueryOptions,
|
|
1648
1644
|
): Observable<RawQueryResponse<R>>
|
|
1649
1645
|
}
|
|
1650
1646
|
|
|
@@ -2580,9 +2576,7 @@ export declare class SanityStegaClient extends SanityClient {
|
|
|
2580
2576
|
fetch<R = Any, Q = QueryParams>(
|
|
2581
2577
|
query: string,
|
|
2582
2578
|
params: Q | undefined,
|
|
2583
|
-
options: FilteredResponseQueryOptions
|
|
2584
|
-
stega?: boolean | StegaConfig
|
|
2585
|
-
},
|
|
2579
|
+
options: FilteredResponseQueryOptions,
|
|
2586
2580
|
): Promise<R>
|
|
2587
2581
|
/**
|
|
2588
2582
|
* Perform a GROQ-query against the configured dataset.
|
|
@@ -2594,9 +2588,7 @@ export declare class SanityStegaClient extends SanityClient {
|
|
|
2594
2588
|
fetch<R = Any, Q = QueryParams>(
|
|
2595
2589
|
query: string,
|
|
2596
2590
|
params: Q | undefined,
|
|
2597
|
-
options: UnfilteredResponseQueryOptions
|
|
2598
|
-
stega?: boolean | StegaConfig
|
|
2599
|
-
},
|
|
2591
|
+
options: UnfilteredResponseQueryOptions,
|
|
2600
2592
|
): Promise<RawQueryResponse<R>>
|
|
2601
2593
|
}
|
|
2602
2594
|
|
package/dist/stega.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { ObservableSanityClient, defaultConfig, SanityClient, defineCreateClientExports, middleware } from './_chunks/nodeMiddleware-
|
|
2
|
-
export { BasePatch, BaseTransaction, ClientError, ObservablePatch, ObservableTransaction, Patch, ServerError, Transaction } from './_chunks/nodeMiddleware-
|
|
1
|
+
import { ObservableSanityClient, defaultConfig, SanityClient, defineCreateClientExports, middleware } from './_chunks/nodeMiddleware-_IDbqRDk.js';
|
|
2
|
+
export { BasePatch, BaseTransaction, ClientError, ObservablePatch, ObservableTransaction, Patch, ServerError, Transaction } from './_chunks/nodeMiddleware-_IDbqRDk.js';
|
|
3
3
|
import { map } from 'rxjs/operators';
|
|
4
4
|
import { vercelStegaCombine, vercelStegaSplit } from '@vercel/stega';
|
|
5
5
|
import { walkMap, resolveMapping, parseJsonPath, resolveStudioBaseRoute, createEditUrl, reKeySegment, toString, jsonPathToStudioPath } from './_chunks/resolveEditInfo-R2JexMKb.js';
|
|
@@ -40,19 +40,6 @@ const initStegaConfig = (config, prevConfig) => {
|
|
|
40
40
|
}
|
|
41
41
|
return newConfig;
|
|
42
42
|
};
|
|
43
|
-
function splitStegaConfigFromFetchOptions(options, initializedStegaConfig) {
|
|
44
|
-
const {
|
|
45
|
-
stega = {},
|
|
46
|
-
...fetchOptions
|
|
47
|
-
} = options;
|
|
48
|
-
const stegaConfig = initStegaConfig(typeof stega === "boolean" ? {
|
|
49
|
-
enabled: stega
|
|
50
|
-
} : stega, initializedStegaConfig);
|
|
51
|
-
return {
|
|
52
|
-
fetchOptions,
|
|
53
|
-
stegaConfig
|
|
54
|
-
};
|
|
55
|
-
}
|
|
56
43
|
function encodeIntoResult(result, csm, encoder) {
|
|
57
44
|
return walkMap(result, (value, path) => {
|
|
58
45
|
if (typeof value !== "string") {
|
|
@@ -331,12 +318,8 @@ const _ObservableSanityStegaClient = class _ObservableSanityStegaClient extends
|
|
|
331
318
|
});
|
|
332
319
|
}
|
|
333
320
|
fetch(query, params) {
|
|
334
|
-
let
|
|
335
|
-
|
|
336
|
-
stegaConfig,
|
|
337
|
-
fetchOptions: options
|
|
338
|
-
} = splitStegaConfigFromFetchOptions(_options, this.stegaConfig);
|
|
339
|
-
if (!stegaConfig.enabled) {
|
|
321
|
+
let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
|
322
|
+
if (!this.stegaConfig.enabled) {
|
|
340
323
|
return super.fetch(query, params, options);
|
|
341
324
|
}
|
|
342
325
|
const {
|
|
@@ -350,7 +333,7 @@ const _ObservableSanityStegaClient = class _ObservableSanityStegaClient extends
|
|
|
350
333
|
result: _result,
|
|
351
334
|
resultSourceMap
|
|
352
335
|
} = res;
|
|
353
|
-
const result = stegaEncodeSourceMap(_result, resultSourceMap, stegaConfig);
|
|
336
|
+
const result = stegaEncodeSourceMap(_result, resultSourceMap, this.stegaConfig);
|
|
354
337
|
return originalFilterResponse ? result : {
|
|
355
338
|
...res,
|
|
356
339
|
result
|
|
@@ -421,12 +404,8 @@ const _SanityStegaClient = class _SanityStegaClient extends SanityClient {
|
|
|
421
404
|
});
|
|
422
405
|
}
|
|
423
406
|
fetch(query, params) {
|
|
424
|
-
let
|
|
425
|
-
|
|
426
|
-
stegaConfig,
|
|
427
|
-
fetchOptions: options
|
|
428
|
-
} = splitStegaConfigFromFetchOptions(_options, this.stegaConfig);
|
|
429
|
-
if (!stegaConfig.enabled) {
|
|
407
|
+
let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
|
408
|
+
if (!this.stegaConfig.enabled) {
|
|
430
409
|
return super.fetch(query, params, options);
|
|
431
410
|
}
|
|
432
411
|
const {
|
|
@@ -440,7 +419,7 @@ const _SanityStegaClient = class _SanityStegaClient extends SanityClient {
|
|
|
440
419
|
result: _result,
|
|
441
420
|
resultSourceMap
|
|
442
421
|
} = res;
|
|
443
|
-
const result = stegaEncodeSourceMap(_result, resultSourceMap, stegaConfig);
|
|
422
|
+
const result = stegaEncodeSourceMap(_result, resultSourceMap, this.stegaConfig);
|
|
444
423
|
return originalFilterResponse ? result : {
|
|
445
424
|
...res,
|
|
446
425
|
result
|
package/dist/stega.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stega.js","sources":["../src/stega/config.ts","../src/stega/encodeIntoResult.ts","../src/stega/filterDefault.ts","../src/stega/stegaEncodeSourceMap.ts","../src/stega/SanityStegaClient.ts","../src/stega/vercelStegaCleanAll.ts","../src/stega/index.ts"],"sourcesContent":["import type {\n ClientConfig,\n FilteredResponseQueryOptions,\n UnfilteredResponseQueryOptions,\n} from '../types'\nimport type {ClientStegaConfig, InitializedStegaConfig, StegaConfig} from './types'\n\nexport const defaultStegaConfig: StegaConfig = {\n enabled: false,\n filter: (props) => props.filterDefault(props),\n}\n\nexport function splitConfig(config: ClientStegaConfig): {\n clientConfig: ClientConfig\n stegaConfig: StegaConfig\n} {\n const {stega = {}, ...clientConfig} = config\n return {clientConfig, stegaConfig: typeof stega === 'boolean' ? {enabled: stega} : stega}\n}\n\nexport const initStegaConfig = (\n config: Partial<StegaConfig>,\n prevConfig: Partial<StegaConfig>,\n): InitializedStegaConfig => {\n const specifiedConfig = Object.assign({} as StegaConfig, prevConfig, config)\n const newConfig = Object.assign({} as InitializedStegaConfig, defaultStegaConfig, specifiedConfig)\n\n if ('encodeSourceMap' in newConfig) {\n throw new Error(\n `It looks like you're using options meant for '@sanity/preview-kit/client'. 'encodeSourceMap' is not supported in '@sanity/client/stega'. Did you mean 'enabled'?`,\n )\n }\n\n if ('encodeSourceMapAtPath' in newConfig) {\n throw new Error(\n `It looks like you're using options meant for '@sanity/preview-kit/client'. 'encodeSourceMapAtPath' is not supported in '@sanity/client/stega'. Did you mean 'filter'?`,\n )\n }\n\n if (typeof newConfig.enabled !== 'boolean') {\n throw new Error(`config.enabled must be a boolean, received ${newConfig.enabled}`)\n }\n\n if (newConfig.enabled && newConfig.studioUrl === undefined) {\n throw new Error(`config.studioUrl must be defined when config.enabled is true`)\n }\n\n if (\n newConfig.enabled &&\n typeof newConfig.studioUrl !== 'string' &&\n typeof newConfig.studioUrl !== 'function'\n ) {\n throw new Error(\n `config.studioUrl must be a string or a function, received ${newConfig.studioUrl}`,\n )\n }\n\n return newConfig\n}\n\nexport function splitStegaConfigFromFetchOptions(\n options: (FilteredResponseQueryOptions | UnfilteredResponseQueryOptions) & {\n stega?: boolean | StegaConfig\n },\n initializedStegaConfig: InitializedStegaConfig,\n): {\n fetchOptions: FilteredResponseQueryOptions | UnfilteredResponseQueryOptions\n stegaConfig: InitializedStegaConfig\n} {\n const {stega = {}, ...fetchOptions} = options\n const stegaConfig = initStegaConfig(\n typeof stega === 'boolean' ? {enabled: stega} : stega,\n initializedStegaConfig,\n )\n return {fetchOptions, stegaConfig}\n}\n","import {parseJsonPath} from '../csm/jsonPath'\nimport {resolveMapping} from '../csm/resolveMapping'\nimport type {ContentSourceMap} from '../csm/types'\nimport {walkMap} from '../csm/walkMap'\nimport type {Encoder} from './types'\n\n/**\n * @internal\n */\nexport function encodeIntoResult<Result>(\n result: Result,\n csm: ContentSourceMap,\n encoder: Encoder,\n): Result {\n return walkMap(result, (value, path) => {\n // Only map strings, we could extend this in the future to support other types like integers...\n if (typeof value !== 'string') {\n return value\n }\n\n const resolveMappingResult = resolveMapping(path, csm)\n if (!resolveMappingResult) {\n return value\n }\n\n const {mapping, matchedPath} = resolveMappingResult\n if (mapping.type !== 'value') {\n return value\n }\n\n if (mapping.source.type !== 'documentValue') {\n return value\n }\n\n const sourceDocument = csm.documents[mapping.source.document!]\n const sourcePath = csm.paths[mapping.source.path]\n\n const matchPathSegments = parseJsonPath(matchedPath)\n const sourcePathSegments = parseJsonPath(sourcePath)\n const fullSourceSegments = sourcePathSegments.concat(path.slice(matchPathSegments.length))\n\n return encoder({\n sourcePath: fullSourceSegments,\n sourceDocument,\n resultPath: path,\n value,\n })\n }) as Result\n}\n","import type {FilterDefault} from './types'\n\nexport const filterDefault: FilterDefault = ({sourcePath, value}) => {\n // Skips encoding on URL or Date strings, similar to the `skip: 'auto'` parameter in vercelStegaCombine()\n if (isValidDate(value) || isValidURL(value)) {\n return false\n }\n\n const endPath = sourcePath.at(-1)\n // Never encode slugs\n if (sourcePath.at(-2) === 'slug' && endPath === 'current') {\n return false\n }\n\n // Skip underscored keys, needs better heuristics but it works for now\n if (typeof endPath === 'string' && endPath.startsWith('_')) {\n return false\n }\n\n /**\n * Best effort infer Portable Text paths that should not be encoded.\n * Nothing is for certain, and the below implementation may cause paths that aren't Portable Text and otherwise be safe to encode to be skipped.\n * However, that's ok as userland can always opt-in with the `encodeSourceMapAtPath` option and mark known safe paths as such, which will override this heuristic.\n */\n // If the path ends in marks[number] it's likely a PortableTextSpan: https://github.com/portabletext/types/blob/e54eb24f136d8efd51a46c6a190e7c46e79b5380/src/portableText.ts#LL154C16-L154C16\n if (typeof endPath === 'number' && sourcePath.at(-2) === 'marks') {\n return false\n }\n // Or if it's [number].markDefs[number].href it's likely a PortableTextLink: https://github.com/portabletext/types/blob/e54eb24f136d8efd51a46c6a190e7c46e79b5380/src/portableText.ts#L163\n if (\n endPath === 'href' &&\n typeof sourcePath.at(-2) === 'number' &&\n sourcePath.at(-3) === 'markDefs'\n ) {\n return false\n }\n // Otherwise we have to deal with special properties of PortableTextBlock, and we can't confidently know if it's actually a `_type: 'block'` array item or not.\n // All we know is that if it is indeed a block, and we encode the strings on these keys it'll for sure break the PortableText rendering and thus we skip encoding.\n // https://github.com/portabletext/types/blob/e54eb24f136d8efd51a46c6a190e7c46e79b5380/src/portableText.ts#L48-L58\n if (endPath === 'style' || endPath === 'listItem') {\n return false\n }\n\n // Don't encode into anything that is suggested it'll render for SEO in meta tags\n if (\n sourcePath.some(\n (path) => path === 'meta' || path === 'metadata' || path === 'openGraph' || path === 'seo',\n )\n ) {\n return false\n }\n\n // Finally, we ignore a bunch of paths that are typically used for page building\n if (typeof endPath === 'string' && denylist.has(endPath)) {\n return false\n }\n\n return true\n}\n\nconst denylist = new Set([\n 'color',\n 'colour',\n 'currency',\n 'email',\n 'format',\n 'gid',\n 'hex',\n 'href',\n 'hsl',\n 'hsla',\n 'icon',\n 'id',\n 'index',\n 'key',\n 'language',\n 'layout',\n 'link',\n 'linkAction',\n 'locale',\n 'lqip',\n 'page',\n 'path',\n 'ref',\n 'rgb',\n 'rgba',\n 'route',\n 'secret',\n 'slug',\n 'status',\n 'tag',\n 'template',\n 'theme',\n 'type',\n 'unit',\n 'url',\n 'username',\n 'variant',\n 'website',\n])\n\nfunction isValidDate(dateString: string) {\n return Number.isNaN(Number(dateString)) ? Boolean(Date.parse(dateString)) : false\n}\n\nfunction isValidURL(url: string) {\n try {\n new URL(url, url.startsWith('/') ? 'https://acme.com' : undefined)\n } catch {\n return false\n }\n return true\n}\n","import {vercelStegaCombine} from '@vercel/stega'\n\nimport {createEditUrl} from '../csm/createEditUrl'\nimport {jsonPathToStudioPath} from '../csm/jsonPath'\nimport {resolveStudioBaseRoute} from '../csm/resolveEditInfo'\nimport {reKeySegment, toString as studioPathToString} from '../csm/studioPath'\nimport {encodeIntoResult} from './encodeIntoResult'\nimport {filterDefault} from './filterDefault'\nimport {ContentSourceMap, ContentSourceMapParsedPath, InitializedStegaConfig} from './types'\n\nconst TRUNCATE_LENGTH = 20\n\n/**\n * Uses `@vercel/stega` to embed edit info JSON into strings in your query result.\n * The JSON payloads are added using invisible characters so they don't show up visually.\n * The edit info is generated from the Content Source Map (CSM) that is returned from Sanity for the query.\n * @public\n */\nexport function stegaEncodeSourceMap<Result = unknown>(\n result: Result,\n resultSourceMap: ContentSourceMap | undefined,\n config: InitializedStegaConfig,\n): Result {\n const {filter, logger, enabled} = config\n if (!enabled) {\n const msg = \"config.enabled must be true, don't call this function otherwise\"\n logger?.error?.(`[@sanity/client/stega]: ${msg}`, {result, resultSourceMap, config})\n throw new TypeError(msg)\n }\n\n if (!resultSourceMap) {\n logger?.error?.('[@sanity/client/stega]: Missing Content Source Map from response body', {\n result,\n resultSourceMap,\n config,\n })\n return result\n }\n\n if (!config.studioUrl) {\n const msg = 'config.studioUrl must be defined'\n logger?.error?.(`[@sanity/client/stega]: ${msg}`, {result, resultSourceMap, config})\n throw new TypeError(msg)\n }\n\n const report: Record<'encoded' | 'skipped', {path: string; length: number; value: string}[]> = {\n encoded: [],\n skipped: [],\n }\n\n const resultWithStega = encodeIntoResult(\n result,\n resultSourceMap,\n ({sourcePath, sourceDocument, resultPath, value}) => {\n // Allow userland to control when to opt-out of encoding\n if (\n (typeof filter === 'function'\n ? filter({sourcePath, resultPath, filterDefault, sourceDocument, value})\n : filterDefault({sourcePath, resultPath, filterDefault, sourceDocument, value})) === false\n ) {\n if (logger) {\n report.skipped.push({\n path: prettyPathForLogging(sourcePath),\n value: `${value.slice(0, TRUNCATE_LENGTH)}${\n value.length > TRUNCATE_LENGTH ? '...' : ''\n }`,\n length: value.length,\n })\n }\n return value\n }\n\n if (logger) {\n report.encoded.push({\n path: prettyPathForLogging(sourcePath),\n value: `${value.slice(0, TRUNCATE_LENGTH)}${value.length > TRUNCATE_LENGTH ? '...' : ''}`,\n length: value.length,\n })\n }\n\n const {baseUrl, workspace, tool} = resolveStudioBaseRoute(\n typeof config.studioUrl === 'function'\n ? config.studioUrl(sourceDocument)\n : config.studioUrl!,\n )\n if (!baseUrl) return value\n const {_id: id, _type: type} = sourceDocument\n\n return vercelStegaCombine(\n value,\n {\n origin: 'sanity.io',\n href: createEditUrl({\n baseUrl,\n workspace,\n tool,\n id,\n type,\n path: sourcePath,\n }),\n },\n // We use custom logic to determine if we should skip encoding\n false,\n )\n },\n )\n\n if (logger) {\n const isSkipping = report.skipped.length\n const isEncoding = report.encoded.length\n if (isSkipping || isEncoding) {\n ;(logger?.groupCollapsed || logger.log)?.(\n '[@sanity/client/stega]: Encoding source map into result',\n )\n logger.log?.(\n `[@sanity/client/stega]: Paths encoded: ${report.encoded.length}, skipped: ${report.skipped.length}`,\n )\n }\n if (report.encoded.length > 0) {\n logger?.log?.(`[@sanity/client/stega]: Table of encoded paths`)\n ;(logger?.table || logger.log)?.(report.encoded)\n }\n if (report.skipped.length > 0) {\n const skipped = new Set<string>()\n for (const {path} of report.skipped) {\n skipped.add(path.replace(reKeySegment, '0').replace(/\\[\\d+\\]/g, '[]'))\n }\n logger?.log?.(`[@sanity/client/stega]: List of skipped paths`, [...skipped.values()])\n }\n\n if (isSkipping || isEncoding) {\n logger?.groupEnd?.()\n }\n }\n\n return resultWithStega\n}\n\nfunction prettyPathForLogging(path: ContentSourceMapParsedPath): string {\n return studioPathToString(jsonPathToStudioPath(path))\n}\n","import {Observable} from 'rxjs'\nimport {map} from 'rxjs/operators'\n\nimport {defaultConfig} from '../config'\nimport {ObservableSanityClient, SanityClient} from '../SanityClient'\nimport type {\n Any,\n ClientConfig,\n FilteredResponseQueryOptions,\n HttpRequest,\n QueryParams,\n RawQueryResponse,\n UnfilteredResponseQueryOptions,\n} from '../types'\nimport {\n defaultStegaConfig,\n initStegaConfig,\n splitConfig,\n splitStegaConfigFromFetchOptions,\n} from './config'\nimport {stegaEncodeSourceMap} from './stegaEncodeSourceMap'\nimport {\n ClientStegaConfig,\n InitializedClientStegaConfig,\n InitializedStegaConfig,\n StegaConfig,\n} from './types'\n\n/** @public */\nexport class ObservableSanityStegaClient extends ObservableSanityClient {\n /**\n * Private properties\n */\n #httpRequest: HttpRequest\n private stegaConfig: InitializedStegaConfig\n\n constructor(httpRequest: HttpRequest, config: ClientStegaConfig = defaultConfig) {\n const {clientConfig, stegaConfig} = splitConfig(config)\n super(httpRequest, clientConfig)\n\n this.#httpRequest = httpRequest\n this.stegaConfig = initStegaConfig(stegaConfig, defaultStegaConfig)\n }\n\n /**\n * Clone the client - returns a new instance\n */\n clone(): ObservableSanityStegaClient {\n return new ObservableSanityStegaClient(this.#httpRequest, this.config())\n }\n\n /**\n * Returns the current client configuration\n */\n config(): InitializedClientStegaConfig\n /**\n * Reconfigure the client. Note that this _mutates_ the current client.\n */\n config(newConfig?: Partial<ClientStegaConfig>): this\n config(newConfig?: Partial<ClientStegaConfig>): ClientStegaConfig | this {\n if (newConfig === undefined) {\n return {...super.config(), stega: {...this.stegaConfig}}\n }\n\n const {clientConfig, stegaConfig} = splitConfig(newConfig)\n super.config(clientConfig)\n\n this.stegaConfig = initStegaConfig(stegaConfig, this.stegaConfig || {})\n return this\n }\n\n /**\n * Clone the client with a new (partial) configuration.\n *\n * @param newConfig - New client configuration properties, shallowly merged with existing configuration\n */\n withConfig(newConfig?: Partial<ClientConfig>): ObservableSanityStegaClient {\n const thisConfig = this.config()\n const {stegaConfig} = splitConfig(newConfig || {})\n return new ObservableSanityStegaClient(this.#httpRequest, {\n ...thisConfig,\n ...newConfig,\n stega: {\n ...(thisConfig.stega || {}),\n ...(stegaConfig || {}),\n },\n })\n }\n\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n */\n fetch<R = Any>(query: string): Observable<R>\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n * @param params - Query parameters\n */\n fetch<R = Any, Q = QueryParams>(query: string, params: Q): Observable<R>\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n * @param params - Query parameters\n * @param options - Request options\n */\n fetch<R = Any, Q = QueryParams>(\n query: string,\n params: Q | undefined,\n options: FilteredResponseQueryOptions & {stega?: boolean | StegaConfig},\n ): Observable<R>\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n * @param params - Query parameters\n * @param options - Request options\n */\n fetch<R = Any, Q = QueryParams>(\n query: string,\n params: Q | undefined,\n options: UnfilteredResponseQueryOptions & {stega?: boolean | StegaConfig},\n ): Observable<RawQueryResponse<R>>\n fetch<R, Q extends QueryParams>(\n query: string,\n params?: Q,\n _options: (FilteredResponseQueryOptions | UnfilteredResponseQueryOptions) & {\n stega?: boolean | StegaConfig\n } = {},\n ): Observable<RawQueryResponse<R> | R> {\n const {stegaConfig, fetchOptions: options} = splitStegaConfigFromFetchOptions(\n _options,\n this.stegaConfig,\n )\n if (!stegaConfig.enabled) {\n return super.fetch<R, Q>(query, params, options as Any)\n }\n const {filterResponse: originalFilterResponse = true} = options\n return super\n .fetch<R, Q>(\n query,\n params,\n Object.assign({}, options as Any, {\n filterResponse: false,\n resultSourceMap: 'withKeyArraySelector',\n }),\n )\n .pipe(\n map((res: Any) => {\n const {result: _result, resultSourceMap} = res as RawQueryResponse<R>\n const result = stegaEncodeSourceMap(_result, resultSourceMap, stegaConfig)\n return originalFilterResponse ? result : {...res, result}\n }),\n )\n }\n}\n\n/** @public */\nexport class SanityStegaClient extends SanityClient {\n /**\n * Observable version of the Sanity client, with the same configuration as the promise-based one\n */\n observable: ObservableSanityStegaClient\n\n /**\n * Private properties\n */\n #httpRequest: HttpRequest\n private stegaConfig: InitializedStegaConfig\n\n constructor(httpRequest: HttpRequest, config: ClientStegaConfig = defaultConfig) {\n const {clientConfig, stegaConfig} = splitConfig(config)\n super(httpRequest, clientConfig)\n\n this.#httpRequest = httpRequest\n this.stegaConfig = initStegaConfig(stegaConfig, defaultStegaConfig)\n\n this.observable = new ObservableSanityStegaClient(httpRequest, config)\n }\n\n /**\n * Clone the client - returns a new instance\n */\n clone(): SanityStegaClient {\n return new SanityStegaClient(this.#httpRequest, this.config())\n }\n\n /**\n * Returns the current client configuration\n */\n config(): InitializedClientStegaConfig\n /**\n * Reconfigure the client. Note that this _mutates_ the current client.\n */\n config(newConfig?: Partial<ClientStegaConfig>): this\n config(newConfig?: Partial<ClientStegaConfig>): ClientStegaConfig | this {\n if (newConfig === undefined) {\n return {...super.config(), stega: {...this.stegaConfig}}\n }\n\n const {clientConfig, stegaConfig} = splitConfig(newConfig)\n super.config(clientConfig)\n\n this.stegaConfig = initStegaConfig(stegaConfig, {...(this.stegaConfig || {})})\n return this\n }\n\n /**\n * Clone the client with a new (partial) configuration.\n *\n * @param newConfig - New client configuration properties, shallowly merged with existing configuration\n */\n withConfig(newConfig?: Partial<ClientStegaConfig>): SanityStegaClient {\n const thisConfig = this.config()\n const {stegaConfig} = splitConfig(newConfig || {})\n return new SanityStegaClient(this.#httpRequest, {\n ...thisConfig,\n ...newConfig,\n stega: {\n ...(thisConfig.stega || {}),\n ...(stegaConfig || {}),\n },\n })\n }\n\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n */\n fetch<R = Any>(query: string): Promise<R>\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n * @param params - Optional query parameters\n */\n fetch<R = Any, Q = QueryParams>(query: string, params: Q): Promise<R>\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n * @param params - Optional query parameters\n * @param options - Request options\n */\n fetch<R = Any, Q = QueryParams>(\n query: string,\n params: Q | undefined,\n options: FilteredResponseQueryOptions & {stega?: boolean | StegaConfig},\n ): Promise<R>\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n * @param params - Optional query parameters\n * @param options - Request options\n */\n fetch<R = Any, Q = QueryParams>(\n query: string,\n params: Q | undefined,\n options: UnfilteredResponseQueryOptions & {stega?: boolean | StegaConfig},\n ): Promise<RawQueryResponse<R>>\n fetch<R, Q extends QueryParams>(\n query: string,\n params?: Q,\n _options: (FilteredResponseQueryOptions | UnfilteredResponseQueryOptions) & {\n stega?: boolean | StegaConfig\n } = {},\n ): Promise<RawQueryResponse<R> | R> {\n const {stegaConfig, fetchOptions: options} = splitStegaConfigFromFetchOptions(\n _options,\n this.stegaConfig,\n )\n if (!stegaConfig.enabled) {\n return super.fetch<R, Q>(query, params, options as Any)\n }\n const {filterResponse: originalFilterResponse = true} = options\n return super\n .fetch<R, Q>(\n query,\n params,\n Object.assign({}, options as Any, {\n filterResponse: false,\n resultSourceMap: 'withKeyArraySelector',\n }),\n )\n .then((res: Any) => {\n const {result: _result, resultSourceMap} = res as RawQueryResponse<R>\n const result = stegaEncodeSourceMap(_result, resultSourceMap, stegaConfig)\n return originalFilterResponse ? result : {...res, result}\n })\n }\n}\n","import {vercelStegaSplit} from '@vercel/stega'\n\n/**\n * Can take a `result` JSON from a `const {result} = client.fetch(query, params, {filterResponse: false})`\n * and remove all stega-encoded data from it.\n * @alpha\n */\nexport function vercelStegaCleanAll<Result = unknown>(result: Result): Result {\n return JSON.parse(\n JSON.stringify(result, (key, value) => {\n if (typeof value !== 'string') return value\n return vercelStegaSplit(value).cleaned\n }),\n )\n}\n","export * from '../defineCreateClient'\n\nimport defineCreateClientExports from '../defineCreateClient'\nimport envMiddleware from '../http/nodeMiddleware'\nimport {SanityStegaClient} from './SanityStegaClient'\nimport type {ClientStegaConfig} from './types'\n\nconst exp = defineCreateClientExports<SanityStegaClient, ClientStegaConfig>(\n envMiddleware,\n SanityStegaClient,\n)\n\nexport * from './shared'\n\n/** @public */\nexport const requester = exp.requester\n\n/** @public */\nexport const createClient = exp.createClient\n"],"names":["defaultStegaConfig","enabled","filter","props","filterDefault","splitConfig","config","stega","clientConfig","stegaConfig","initStegaConfig","prevConfig","specifiedConfig","Object","assign","newConfig","Error","concat","studioUrl","splitStegaConfigFromFetchOptions","options","initializedStegaConfig","fetchOptions","encodeIntoResult","result","csm","encoder","walkMap","value","path","resolveMappingResult","resolveMapping","mapping","matchedPath","type","source","sourceDocument","documents","document","sourcePath","paths","matchPathSegments","parseJsonPath","sourcePathSegments","fullSourceSegments","slice","length","resultPath","_ref","isValidDate","isValidURL","endPath","at","startsWith","some","denylist","has","Set","dateString","Number","isNaN","Boolean","Date","parse","url","URL","TRUNCATE_LENGTH","stegaEncodeSourceMap","resultSourceMap","_a","_b","_c","_d","_e","_f","_g","_h","_i","logger","msg","error","call","TypeError","report","encoded","skipped","resultWithStega","_ref2","push","prettyPathForLogging","baseUrl","workspace","tool","resolveStudioBaseRoute","_id","id","_type","vercelStegaCombine","origin","href","createEditUrl","isSkipping","isEncoding","groupCollapsed","log","table","add","replace","reKeySegment","values","groupEnd","studioPathToString","jsonPathToStudioPath","_httpRequest","_ObservableSanityStegaClient","ObservableSanityClient","constructor","httpRequest","arguments","undefined","defaultConfig","__privateAdd","__privateSet","clone","__privateGet","withConfig","thisConfig","fetch","query","params","_options","filterResponse","originalFilterResponse","pipe","map","res","_result","WeakMap","ObservableSanityStegaClient","_SanityStegaClient","SanityClient","observable","then","SanityStegaClient","vercelStegaCleanAll","JSON","stringify","key","vercelStegaSplit","cleaned","exp","defineCreateClientExports","envMiddleware","requester","createClient"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"stega.js","sources":["../src/stega/config.ts","../src/stega/encodeIntoResult.ts","../src/stega/filterDefault.ts","../src/stega/stegaEncodeSourceMap.ts","../src/stega/SanityStegaClient.ts","../src/stega/vercelStegaCleanAll.ts","../src/stega/index.ts"],"sourcesContent":["import type {ClientConfig} from '../types'\nimport type {ClientStegaConfig, InitializedStegaConfig, StegaConfig} from './types'\n\nexport const defaultStegaConfig: StegaConfig = {\n enabled: false,\n filter: (props) => props.filterDefault(props),\n}\n\nexport function splitConfig(config: ClientStegaConfig): {\n clientConfig: ClientConfig\n stegaConfig: StegaConfig\n} {\n const {stega = {}, ...clientConfig} = config\n return {clientConfig, stegaConfig: typeof stega === 'boolean' ? {enabled: stega} : stega}\n}\n\nexport const initStegaConfig = (\n config: Partial<StegaConfig>,\n prevConfig: Partial<StegaConfig>,\n): InitializedStegaConfig => {\n const specifiedConfig = Object.assign({} as StegaConfig, prevConfig, config)\n const newConfig = Object.assign({} as InitializedStegaConfig, defaultStegaConfig, specifiedConfig)\n\n if ('encodeSourceMap' in newConfig) {\n throw new Error(\n `It looks like you're using options meant for '@sanity/preview-kit/client'. 'encodeSourceMap' is not supported in '@sanity/client/stega'. Did you mean 'enabled'?`,\n )\n }\n\n if ('encodeSourceMapAtPath' in newConfig) {\n throw new Error(\n `It looks like you're using options meant for '@sanity/preview-kit/client'. 'encodeSourceMapAtPath' is not supported in '@sanity/client/stega'. Did you mean 'filter'?`,\n )\n }\n\n if (typeof newConfig.enabled !== 'boolean') {\n throw new Error(`config.enabled must be a boolean, received ${newConfig.enabled}`)\n }\n\n if (newConfig.enabled && newConfig.studioUrl === undefined) {\n throw new Error(`config.studioUrl must be defined when config.enabled is true`)\n }\n\n if (\n newConfig.enabled &&\n typeof newConfig.studioUrl !== 'string' &&\n typeof newConfig.studioUrl !== 'function'\n ) {\n throw new Error(\n `config.studioUrl must be a string or a function, received ${newConfig.studioUrl}`,\n )\n }\n\n return newConfig\n}\n","import {parseJsonPath} from '../csm/jsonPath'\nimport {resolveMapping} from '../csm/resolveMapping'\nimport type {ContentSourceMap} from '../csm/types'\nimport {walkMap} from '../csm/walkMap'\nimport type {Encoder} from './types'\n\n/**\n * @internal\n */\nexport function encodeIntoResult<Result>(\n result: Result,\n csm: ContentSourceMap,\n encoder: Encoder,\n): Result {\n return walkMap(result, (value, path) => {\n // Only map strings, we could extend this in the future to support other types like integers...\n if (typeof value !== 'string') {\n return value\n }\n\n const resolveMappingResult = resolveMapping(path, csm)\n if (!resolveMappingResult) {\n return value\n }\n\n const {mapping, matchedPath} = resolveMappingResult\n if (mapping.type !== 'value') {\n return value\n }\n\n if (mapping.source.type !== 'documentValue') {\n return value\n }\n\n const sourceDocument = csm.documents[mapping.source.document!]\n const sourcePath = csm.paths[mapping.source.path]\n\n const matchPathSegments = parseJsonPath(matchedPath)\n const sourcePathSegments = parseJsonPath(sourcePath)\n const fullSourceSegments = sourcePathSegments.concat(path.slice(matchPathSegments.length))\n\n return encoder({\n sourcePath: fullSourceSegments,\n sourceDocument,\n resultPath: path,\n value,\n })\n }) as Result\n}\n","import type {FilterDefault} from './types'\n\nexport const filterDefault: FilterDefault = ({sourcePath, value}) => {\n // Skips encoding on URL or Date strings, similar to the `skip: 'auto'` parameter in vercelStegaCombine()\n if (isValidDate(value) || isValidURL(value)) {\n return false\n }\n\n const endPath = sourcePath.at(-1)\n // Never encode slugs\n if (sourcePath.at(-2) === 'slug' && endPath === 'current') {\n return false\n }\n\n // Skip underscored keys, needs better heuristics but it works for now\n if (typeof endPath === 'string' && endPath.startsWith('_')) {\n return false\n }\n\n /**\n * Best effort infer Portable Text paths that should not be encoded.\n * Nothing is for certain, and the below implementation may cause paths that aren't Portable Text and otherwise be safe to encode to be skipped.\n * However, that's ok as userland can always opt-in with the `encodeSourceMapAtPath` option and mark known safe paths as such, which will override this heuristic.\n */\n // If the path ends in marks[number] it's likely a PortableTextSpan: https://github.com/portabletext/types/blob/e54eb24f136d8efd51a46c6a190e7c46e79b5380/src/portableText.ts#LL154C16-L154C16\n if (typeof endPath === 'number' && sourcePath.at(-2) === 'marks') {\n return false\n }\n // Or if it's [number].markDefs[number].href it's likely a PortableTextLink: https://github.com/portabletext/types/blob/e54eb24f136d8efd51a46c6a190e7c46e79b5380/src/portableText.ts#L163\n if (\n endPath === 'href' &&\n typeof sourcePath.at(-2) === 'number' &&\n sourcePath.at(-3) === 'markDefs'\n ) {\n return false\n }\n // Otherwise we have to deal with special properties of PortableTextBlock, and we can't confidently know if it's actually a `_type: 'block'` array item or not.\n // All we know is that if it is indeed a block, and we encode the strings on these keys it'll for sure break the PortableText rendering and thus we skip encoding.\n // https://github.com/portabletext/types/blob/e54eb24f136d8efd51a46c6a190e7c46e79b5380/src/portableText.ts#L48-L58\n if (endPath === 'style' || endPath === 'listItem') {\n return false\n }\n\n // Don't encode into anything that is suggested it'll render for SEO in meta tags\n if (\n sourcePath.some(\n (path) => path === 'meta' || path === 'metadata' || path === 'openGraph' || path === 'seo',\n )\n ) {\n return false\n }\n\n // Finally, we ignore a bunch of paths that are typically used for page building\n if (typeof endPath === 'string' && denylist.has(endPath)) {\n return false\n }\n\n return true\n}\n\nconst denylist = new Set([\n 'color',\n 'colour',\n 'currency',\n 'email',\n 'format',\n 'gid',\n 'hex',\n 'href',\n 'hsl',\n 'hsla',\n 'icon',\n 'id',\n 'index',\n 'key',\n 'language',\n 'layout',\n 'link',\n 'linkAction',\n 'locale',\n 'lqip',\n 'page',\n 'path',\n 'ref',\n 'rgb',\n 'rgba',\n 'route',\n 'secret',\n 'slug',\n 'status',\n 'tag',\n 'template',\n 'theme',\n 'type',\n 'unit',\n 'url',\n 'username',\n 'variant',\n 'website',\n])\n\nfunction isValidDate(dateString: string) {\n return Number.isNaN(Number(dateString)) ? Boolean(Date.parse(dateString)) : false\n}\n\nfunction isValidURL(url: string) {\n try {\n new URL(url, url.startsWith('/') ? 'https://acme.com' : undefined)\n } catch {\n return false\n }\n return true\n}\n","import {vercelStegaCombine} from '@vercel/stega'\n\nimport {createEditUrl} from '../csm/createEditUrl'\nimport {jsonPathToStudioPath} from '../csm/jsonPath'\nimport {resolveStudioBaseRoute} from '../csm/resolveEditInfo'\nimport {reKeySegment, toString as studioPathToString} from '../csm/studioPath'\nimport {encodeIntoResult} from './encodeIntoResult'\nimport {filterDefault} from './filterDefault'\nimport {ContentSourceMap, ContentSourceMapParsedPath, InitializedStegaConfig} from './types'\n\nconst TRUNCATE_LENGTH = 20\n\n/**\n * Uses `@vercel/stega` to embed edit info JSON into strings in your query result.\n * The JSON payloads are added using invisible characters so they don't show up visually.\n * The edit info is generated from the Content Source Map (CSM) that is returned from Sanity for the query.\n * @public\n */\nexport function stegaEncodeSourceMap<Result = unknown>(\n result: Result,\n resultSourceMap: ContentSourceMap | undefined,\n config: InitializedStegaConfig,\n): Result {\n const {filter, logger, enabled} = config\n if (!enabled) {\n const msg = \"config.enabled must be true, don't call this function otherwise\"\n logger?.error?.(`[@sanity/client/stega]: ${msg}`, {result, resultSourceMap, config})\n throw new TypeError(msg)\n }\n\n if (!resultSourceMap) {\n logger?.error?.('[@sanity/client/stega]: Missing Content Source Map from response body', {\n result,\n resultSourceMap,\n config,\n })\n return result\n }\n\n if (!config.studioUrl) {\n const msg = 'config.studioUrl must be defined'\n logger?.error?.(`[@sanity/client/stega]: ${msg}`, {result, resultSourceMap, config})\n throw new TypeError(msg)\n }\n\n const report: Record<'encoded' | 'skipped', {path: string; length: number; value: string}[]> = {\n encoded: [],\n skipped: [],\n }\n\n const resultWithStega = encodeIntoResult(\n result,\n resultSourceMap,\n ({sourcePath, sourceDocument, resultPath, value}) => {\n // Allow userland to control when to opt-out of encoding\n if (\n (typeof filter === 'function'\n ? filter({sourcePath, resultPath, filterDefault, sourceDocument, value})\n : filterDefault({sourcePath, resultPath, filterDefault, sourceDocument, value})) === false\n ) {\n if (logger) {\n report.skipped.push({\n path: prettyPathForLogging(sourcePath),\n value: `${value.slice(0, TRUNCATE_LENGTH)}${\n value.length > TRUNCATE_LENGTH ? '...' : ''\n }`,\n length: value.length,\n })\n }\n return value\n }\n\n if (logger) {\n report.encoded.push({\n path: prettyPathForLogging(sourcePath),\n value: `${value.slice(0, TRUNCATE_LENGTH)}${value.length > TRUNCATE_LENGTH ? '...' : ''}`,\n length: value.length,\n })\n }\n\n const {baseUrl, workspace, tool} = resolveStudioBaseRoute(\n typeof config.studioUrl === 'function'\n ? config.studioUrl(sourceDocument)\n : config.studioUrl!,\n )\n if (!baseUrl) return value\n const {_id: id, _type: type} = sourceDocument\n\n return vercelStegaCombine(\n value,\n {\n origin: 'sanity.io',\n href: createEditUrl({\n baseUrl,\n workspace,\n tool,\n id,\n type,\n path: sourcePath,\n }),\n },\n // We use custom logic to determine if we should skip encoding\n false,\n )\n },\n )\n\n if (logger) {\n const isSkipping = report.skipped.length\n const isEncoding = report.encoded.length\n if (isSkipping || isEncoding) {\n ;(logger?.groupCollapsed || logger.log)?.(\n '[@sanity/client/stega]: Encoding source map into result',\n )\n logger.log?.(\n `[@sanity/client/stega]: Paths encoded: ${report.encoded.length}, skipped: ${report.skipped.length}`,\n )\n }\n if (report.encoded.length > 0) {\n logger?.log?.(`[@sanity/client/stega]: Table of encoded paths`)\n ;(logger?.table || logger.log)?.(report.encoded)\n }\n if (report.skipped.length > 0) {\n const skipped = new Set<string>()\n for (const {path} of report.skipped) {\n skipped.add(path.replace(reKeySegment, '0').replace(/\\[\\d+\\]/g, '[]'))\n }\n logger?.log?.(`[@sanity/client/stega]: List of skipped paths`, [...skipped.values()])\n }\n\n if (isSkipping || isEncoding) {\n logger?.groupEnd?.()\n }\n }\n\n return resultWithStega\n}\n\nfunction prettyPathForLogging(path: ContentSourceMapParsedPath): string {\n return studioPathToString(jsonPathToStudioPath(path))\n}\n","import {Observable} from 'rxjs'\nimport {map} from 'rxjs/operators'\n\nimport {defaultConfig} from '../config'\nimport {ObservableSanityClient, SanityClient} from '../SanityClient'\nimport type {\n Any,\n ClientConfig,\n FilteredResponseQueryOptions,\n HttpRequest,\n QueryParams,\n RawQueryResponse,\n UnfilteredResponseQueryOptions,\n} from '../types'\nimport {defaultStegaConfig, initStegaConfig, splitConfig} from './config'\nimport {stegaEncodeSourceMap} from './stegaEncodeSourceMap'\nimport {ClientStegaConfig, InitializedClientStegaConfig, InitializedStegaConfig} from './types'\n\n/** @public */\nexport class ObservableSanityStegaClient extends ObservableSanityClient {\n /**\n * Private properties\n */\n #httpRequest: HttpRequest\n private stegaConfig: InitializedStegaConfig\n\n constructor(httpRequest: HttpRequest, config: ClientStegaConfig = defaultConfig) {\n const {clientConfig, stegaConfig} = splitConfig(config)\n super(httpRequest, clientConfig)\n\n this.#httpRequest = httpRequest\n this.stegaConfig = initStegaConfig(stegaConfig, defaultStegaConfig)\n }\n\n /**\n * Clone the client - returns a new instance\n */\n clone(): ObservableSanityStegaClient {\n return new ObservableSanityStegaClient(this.#httpRequest, this.config())\n }\n\n /**\n * Returns the current client configuration\n */\n config(): InitializedClientStegaConfig\n /**\n * Reconfigure the client. Note that this _mutates_ the current client.\n */\n config(newConfig?: Partial<ClientStegaConfig>): this\n config(newConfig?: Partial<ClientStegaConfig>): ClientStegaConfig | this {\n if (newConfig === undefined) {\n return {...super.config(), stega: {...this.stegaConfig}}\n }\n\n const {clientConfig, stegaConfig} = splitConfig(newConfig)\n super.config(clientConfig)\n\n this.stegaConfig = initStegaConfig(stegaConfig, this.stegaConfig || {})\n return this\n }\n\n /**\n * Clone the client with a new (partial) configuration.\n *\n * @param newConfig - New client configuration properties, shallowly merged with existing configuration\n */\n withConfig(newConfig?: Partial<ClientConfig>): ObservableSanityStegaClient {\n const thisConfig = this.config()\n const {stegaConfig} = splitConfig(newConfig || {})\n return new ObservableSanityStegaClient(this.#httpRequest, {\n ...thisConfig,\n ...newConfig,\n stega: {\n ...(thisConfig.stega || {}),\n ...(stegaConfig || {}),\n },\n })\n }\n\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n */\n fetch<R = Any>(query: string): Observable<R>\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n * @param params - Query parameters\n */\n fetch<R = Any, Q = QueryParams>(query: string, params: Q): Observable<R>\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n * @param params - Query parameters\n * @param options - Request options\n */\n fetch<R = Any, Q = QueryParams>(\n query: string,\n params: Q | undefined,\n options: FilteredResponseQueryOptions,\n ): Observable<R>\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n * @param params - Query parameters\n * @param options - Request options\n */\n fetch<R = Any, Q = QueryParams>(\n query: string,\n params: Q | undefined,\n options: UnfilteredResponseQueryOptions,\n ): Observable<RawQueryResponse<R>>\n fetch<R, Q extends QueryParams>(\n query: string,\n params?: Q,\n options: FilteredResponseQueryOptions | UnfilteredResponseQueryOptions = {},\n ): Observable<RawQueryResponse<R> | R> {\n if (!this.stegaConfig.enabled) {\n return super.fetch<R, Q>(query, params, options as Any)\n }\n const {filterResponse: originalFilterResponse = true} = options\n return super\n .fetch<R, Q>(\n query,\n params,\n Object.assign({}, options as Any, {\n filterResponse: false,\n resultSourceMap: 'withKeyArraySelector',\n }),\n )\n .pipe(\n map((res: Any) => {\n const {result: _result, resultSourceMap} = res as RawQueryResponse<R>\n const result = stegaEncodeSourceMap(_result, resultSourceMap, this.stegaConfig)\n return originalFilterResponse ? result : {...res, result}\n }),\n )\n }\n}\n\n/** @public */\nexport class SanityStegaClient extends SanityClient {\n /**\n * Observable version of the Sanity client, with the same configuration as the promise-based one\n */\n observable: ObservableSanityStegaClient\n\n /**\n * Private properties\n */\n #httpRequest: HttpRequest\n private stegaConfig: InitializedStegaConfig\n\n constructor(httpRequest: HttpRequest, config: ClientStegaConfig = defaultConfig) {\n const {clientConfig, stegaConfig} = splitConfig(config)\n super(httpRequest, clientConfig)\n\n this.#httpRequest = httpRequest\n this.stegaConfig = initStegaConfig(stegaConfig, defaultStegaConfig)\n\n this.observable = new ObservableSanityStegaClient(httpRequest, config)\n }\n\n /**\n * Clone the client - returns a new instance\n */\n clone(): SanityStegaClient {\n return new SanityStegaClient(this.#httpRequest, this.config())\n }\n\n /**\n * Returns the current client configuration\n */\n config(): InitializedClientStegaConfig\n /**\n * Reconfigure the client. Note that this _mutates_ the current client.\n */\n config(newConfig?: Partial<ClientStegaConfig>): this\n config(newConfig?: Partial<ClientStegaConfig>): ClientStegaConfig | this {\n if (newConfig === undefined) {\n return {...super.config(), stega: {...this.stegaConfig}}\n }\n\n const {clientConfig, stegaConfig} = splitConfig(newConfig)\n super.config(clientConfig)\n\n this.stegaConfig = initStegaConfig(stegaConfig, {...(this.stegaConfig || {})})\n return this\n }\n\n /**\n * Clone the client with a new (partial) configuration.\n *\n * @param newConfig - New client configuration properties, shallowly merged with existing configuration\n */\n withConfig(newConfig?: Partial<ClientStegaConfig>): SanityStegaClient {\n const thisConfig = this.config()\n const {stegaConfig} = splitConfig(newConfig || {})\n return new SanityStegaClient(this.#httpRequest, {\n ...thisConfig,\n ...newConfig,\n stega: {\n ...(thisConfig.stega || {}),\n ...(stegaConfig || {}),\n },\n })\n }\n\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n */\n fetch<R = Any>(query: string): Promise<R>\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n * @param params - Optional query parameters\n */\n fetch<R = Any, Q = QueryParams>(query: string, params: Q): Promise<R>\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n * @param params - Optional query parameters\n * @param options - Request options\n */\n fetch<R = Any, Q = QueryParams>(\n query: string,\n params: Q | undefined,\n options: FilteredResponseQueryOptions,\n ): Promise<R>\n /**\n * Perform a GROQ-query against the configured dataset.\n *\n * @param query - GROQ-query to perform\n * @param params - Optional query parameters\n * @param options - Request options\n */\n fetch<R = Any, Q = QueryParams>(\n query: string,\n params: Q | undefined,\n options: UnfilteredResponseQueryOptions,\n ): Promise<RawQueryResponse<R>>\n fetch<R, Q extends QueryParams>(\n query: string,\n params?: Q,\n options: FilteredResponseQueryOptions | UnfilteredResponseQueryOptions = {},\n ): Promise<RawQueryResponse<R> | R> {\n if (!this.stegaConfig.enabled) {\n return super.fetch<R, Q>(query, params, options as Any)\n }\n const {filterResponse: originalFilterResponse = true} = options\n return super\n .fetch<R, Q>(\n query,\n params,\n Object.assign({}, options as Any, {\n filterResponse: false,\n resultSourceMap: 'withKeyArraySelector',\n }),\n )\n .then((res: Any) => {\n const {result: _result, resultSourceMap} = res as RawQueryResponse<R>\n const result = stegaEncodeSourceMap(_result, resultSourceMap, this.stegaConfig)\n return originalFilterResponse ? result : {...res, result}\n })\n }\n}\n","import {vercelStegaSplit} from '@vercel/stega'\n\n/**\n * Can take a `result` JSON from a `const {result} = client.fetch(query, params, {filterResponse: false})`\n * and remove all stega-encoded data from it.\n * @alpha\n */\nexport function vercelStegaCleanAll<Result = unknown>(result: Result): Result {\n return JSON.parse(\n JSON.stringify(result, (key, value) => {\n if (typeof value !== 'string') return value\n return vercelStegaSplit(value).cleaned\n }),\n )\n}\n","export * from '../defineCreateClient'\n\nimport defineCreateClientExports from '../defineCreateClient'\nimport envMiddleware from '../http/nodeMiddleware'\nimport {SanityStegaClient} from './SanityStegaClient'\nimport type {ClientStegaConfig} from './types'\n\nconst exp = defineCreateClientExports<SanityStegaClient, ClientStegaConfig>(\n envMiddleware,\n SanityStegaClient,\n)\n\nexport * from './shared'\n\n/** @public */\nexport const requester = exp.requester\n\n/** @public */\nexport const createClient = exp.createClient\n"],"names":["defaultStegaConfig","enabled","filter","props","filterDefault","splitConfig","config","stega","clientConfig","stegaConfig","initStegaConfig","prevConfig","specifiedConfig","Object","assign","newConfig","Error","concat","studioUrl","encodeIntoResult","result","csm","encoder","walkMap","value","path","resolveMappingResult","resolveMapping","mapping","matchedPath","type","source","sourceDocument","documents","document","sourcePath","paths","matchPathSegments","parseJsonPath","sourcePathSegments","fullSourceSegments","slice","length","resultPath","_ref","isValidDate","isValidURL","endPath","at","startsWith","some","denylist","has","Set","dateString","Number","isNaN","Boolean","Date","parse","url","URL","TRUNCATE_LENGTH","stegaEncodeSourceMap","resultSourceMap","_a","_b","_c","_d","_e","_f","_g","_h","_i","logger","msg","error","call","TypeError","report","encoded","skipped","resultWithStega","_ref2","push","prettyPathForLogging","baseUrl","workspace","tool","resolveStudioBaseRoute","_id","id","_type","vercelStegaCombine","origin","href","createEditUrl","isSkipping","isEncoding","groupCollapsed","log","table","add","replace","reKeySegment","values","groupEnd","studioPathToString","jsonPathToStudioPath","_httpRequest","_ObservableSanityStegaClient","ObservableSanityClient","constructor","httpRequest","arguments","undefined","defaultConfig","__privateAdd","__privateSet","clone","__privateGet","withConfig","thisConfig","fetch","query","params","options","filterResponse","originalFilterResponse","pipe","map","res","_result","WeakMap","ObservableSanityStegaClient","_SanityStegaClient","SanityClient","observable","then","SanityStegaClient","vercelStegaCleanAll","JSON","stringify","key","vercelStegaSplit","cleaned","exp","defineCreateClientExports","envMiddleware","requester","createClient"],"mappings":"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"}
|
package/package.json
CHANGED
package/src/data/dataMethods.ts
CHANGED
|
@@ -69,11 +69,6 @@ export function _fetch<R, Q extends QueryParams>(
|
|
|
69
69
|
params?: Q,
|
|
70
70
|
options: FilteredResponseQueryOptions | UnfilteredResponseQueryOptions = {},
|
|
71
71
|
): Observable<RawQueryResponse<R> | R> {
|
|
72
|
-
if ('stega' in options && options['stega'] !== undefined && options['stega'] !== false) {
|
|
73
|
-
throw new Error(
|
|
74
|
-
`It looks like you're using options meant for '@sanity/client/stega'. Make sure you're using the right import. Or set 'stega' in 'fetch' to 'false'.`,
|
|
75
|
-
)
|
|
76
|
-
}
|
|
77
72
|
const mapResponse =
|
|
78
73
|
options.filterResponse === false ? (res: Any) => res : (res: Any) => res.result
|
|
79
74
|
const {cache, next, ...opts} = {
|
|
@@ -12,19 +12,9 @@ import type {
|
|
|
12
12
|
RawQueryResponse,
|
|
13
13
|
UnfilteredResponseQueryOptions,
|
|
14
14
|
} from '../types'
|
|
15
|
-
import {
|
|
16
|
-
defaultStegaConfig,
|
|
17
|
-
initStegaConfig,
|
|
18
|
-
splitConfig,
|
|
19
|
-
splitStegaConfigFromFetchOptions,
|
|
20
|
-
} from './config'
|
|
15
|
+
import {defaultStegaConfig, initStegaConfig, splitConfig} from './config'
|
|
21
16
|
import {stegaEncodeSourceMap} from './stegaEncodeSourceMap'
|
|
22
|
-
import {
|
|
23
|
-
ClientStegaConfig,
|
|
24
|
-
InitializedClientStegaConfig,
|
|
25
|
-
InitializedStegaConfig,
|
|
26
|
-
StegaConfig,
|
|
27
|
-
} from './types'
|
|
17
|
+
import {ClientStegaConfig, InitializedClientStegaConfig, InitializedStegaConfig} from './types'
|
|
28
18
|
|
|
29
19
|
/** @public */
|
|
30
20
|
export class ObservableSanityStegaClient extends ObservableSanityClient {
|
|
@@ -110,7 +100,7 @@ export class ObservableSanityStegaClient extends ObservableSanityClient {
|
|
|
110
100
|
fetch<R = Any, Q = QueryParams>(
|
|
111
101
|
query: string,
|
|
112
102
|
params: Q | undefined,
|
|
113
|
-
options: FilteredResponseQueryOptions
|
|
103
|
+
options: FilteredResponseQueryOptions,
|
|
114
104
|
): Observable<R>
|
|
115
105
|
/**
|
|
116
106
|
* Perform a GROQ-query against the configured dataset.
|
|
@@ -122,20 +112,14 @@ export class ObservableSanityStegaClient extends ObservableSanityClient {
|
|
|
122
112
|
fetch<R = Any, Q = QueryParams>(
|
|
123
113
|
query: string,
|
|
124
114
|
params: Q | undefined,
|
|
125
|
-
options: UnfilteredResponseQueryOptions
|
|
115
|
+
options: UnfilteredResponseQueryOptions,
|
|
126
116
|
): Observable<RawQueryResponse<R>>
|
|
127
117
|
fetch<R, Q extends QueryParams>(
|
|
128
118
|
query: string,
|
|
129
119
|
params?: Q,
|
|
130
|
-
|
|
131
|
-
stega?: boolean | StegaConfig
|
|
132
|
-
} = {},
|
|
120
|
+
options: FilteredResponseQueryOptions | UnfilteredResponseQueryOptions = {},
|
|
133
121
|
): Observable<RawQueryResponse<R> | R> {
|
|
134
|
-
|
|
135
|
-
_options,
|
|
136
|
-
this.stegaConfig,
|
|
137
|
-
)
|
|
138
|
-
if (!stegaConfig.enabled) {
|
|
122
|
+
if (!this.stegaConfig.enabled) {
|
|
139
123
|
return super.fetch<R, Q>(query, params, options as Any)
|
|
140
124
|
}
|
|
141
125
|
const {filterResponse: originalFilterResponse = true} = options
|
|
@@ -151,7 +135,7 @@ export class ObservableSanityStegaClient extends ObservableSanityClient {
|
|
|
151
135
|
.pipe(
|
|
152
136
|
map((res: Any) => {
|
|
153
137
|
const {result: _result, resultSourceMap} = res as RawQueryResponse<R>
|
|
154
|
-
const result = stegaEncodeSourceMap(_result, resultSourceMap, stegaConfig)
|
|
138
|
+
const result = stegaEncodeSourceMap(_result, resultSourceMap, this.stegaConfig)
|
|
155
139
|
return originalFilterResponse ? result : {...res, result}
|
|
156
140
|
}),
|
|
157
141
|
)
|
|
@@ -249,7 +233,7 @@ export class SanityStegaClient extends SanityClient {
|
|
|
249
233
|
fetch<R = Any, Q = QueryParams>(
|
|
250
234
|
query: string,
|
|
251
235
|
params: Q | undefined,
|
|
252
|
-
options: FilteredResponseQueryOptions
|
|
236
|
+
options: FilteredResponseQueryOptions,
|
|
253
237
|
): Promise<R>
|
|
254
238
|
/**
|
|
255
239
|
* Perform a GROQ-query against the configured dataset.
|
|
@@ -261,20 +245,14 @@ export class SanityStegaClient extends SanityClient {
|
|
|
261
245
|
fetch<R = Any, Q = QueryParams>(
|
|
262
246
|
query: string,
|
|
263
247
|
params: Q | undefined,
|
|
264
|
-
options: UnfilteredResponseQueryOptions
|
|
248
|
+
options: UnfilteredResponseQueryOptions,
|
|
265
249
|
): Promise<RawQueryResponse<R>>
|
|
266
250
|
fetch<R, Q extends QueryParams>(
|
|
267
251
|
query: string,
|
|
268
252
|
params?: Q,
|
|
269
|
-
|
|
270
|
-
stega?: boolean | StegaConfig
|
|
271
|
-
} = {},
|
|
253
|
+
options: FilteredResponseQueryOptions | UnfilteredResponseQueryOptions = {},
|
|
272
254
|
): Promise<RawQueryResponse<R> | R> {
|
|
273
|
-
|
|
274
|
-
_options,
|
|
275
|
-
this.stegaConfig,
|
|
276
|
-
)
|
|
277
|
-
if (!stegaConfig.enabled) {
|
|
255
|
+
if (!this.stegaConfig.enabled) {
|
|
278
256
|
return super.fetch<R, Q>(query, params, options as Any)
|
|
279
257
|
}
|
|
280
258
|
const {filterResponse: originalFilterResponse = true} = options
|
|
@@ -289,7 +267,7 @@ export class SanityStegaClient extends SanityClient {
|
|
|
289
267
|
)
|
|
290
268
|
.then((res: Any) => {
|
|
291
269
|
const {result: _result, resultSourceMap} = res as RawQueryResponse<R>
|
|
292
|
-
const result = stegaEncodeSourceMap(_result, resultSourceMap, stegaConfig)
|
|
270
|
+
const result = stegaEncodeSourceMap(_result, resultSourceMap, this.stegaConfig)
|
|
293
271
|
return originalFilterResponse ? result : {...res, result}
|
|
294
272
|
})
|
|
295
273
|
}
|
package/src/stega/config.ts
CHANGED
|
@@ -1,8 +1,4 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
ClientConfig,
|
|
3
|
-
FilteredResponseQueryOptions,
|
|
4
|
-
UnfilteredResponseQueryOptions,
|
|
5
|
-
} from '../types'
|
|
1
|
+
import type {ClientConfig} from '../types'
|
|
6
2
|
import type {ClientStegaConfig, InitializedStegaConfig, StegaConfig} from './types'
|
|
7
3
|
|
|
8
4
|
export const defaultStegaConfig: StegaConfig = {
|
|
@@ -57,20 +53,3 @@ export const initStegaConfig = (
|
|
|
57
53
|
|
|
58
54
|
return newConfig
|
|
59
55
|
}
|
|
60
|
-
|
|
61
|
-
export function splitStegaConfigFromFetchOptions(
|
|
62
|
-
options: (FilteredResponseQueryOptions | UnfilteredResponseQueryOptions) & {
|
|
63
|
-
stega?: boolean | StegaConfig
|
|
64
|
-
},
|
|
65
|
-
initializedStegaConfig: InitializedStegaConfig,
|
|
66
|
-
): {
|
|
67
|
-
fetchOptions: FilteredResponseQueryOptions | UnfilteredResponseQueryOptions
|
|
68
|
-
stegaConfig: InitializedStegaConfig
|
|
69
|
-
} {
|
|
70
|
-
const {stega = {}, ...fetchOptions} = options
|
|
71
|
-
const stegaConfig = initStegaConfig(
|
|
72
|
-
typeof stega === 'boolean' ? {enabled: stega} : stega,
|
|
73
|
-
initializedStegaConfig,
|
|
74
|
-
)
|
|
75
|
-
return {fetchOptions, stegaConfig}
|
|
76
|
-
}
|
package/umd/sanityClient.js
CHANGED
|
@@ -2924,9 +2924,6 @@
|
|
|
2924
2924
|
const getQuerySizeLimit = 11264;
|
|
2925
2925
|
function _fetch(client, httpRequest, query, params) {
|
|
2926
2926
|
let options = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {};
|
|
2927
|
-
if ("stega" in options && options["stega"] !== void 0 && options["stega"] !== false) {
|
|
2928
|
-
throw new Error("It looks like you're using options meant for '@sanity/client/stega'. Make sure you're using the right import. Or set 'stega' in 'fetch' to 'false'.");
|
|
2929
|
-
}
|
|
2930
2927
|
const mapResponse = options.filterResponse === false ? res => res : res => res.result;
|
|
2931
2928
|
const {
|
|
2932
2929
|
cache,
|