@medplum/fhir-router 4.1.3 → 4.1.4

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.
@@ -1,4 +1,4 @@
1
- import{EventTarget as wc,OperationOutcomeError as Dc,allOk as Ee,badRequest as _e,created as Ac,normalizeOperationOutcome as Fc,notFound as kc,parseSearchRequest as ot,singularize as Cc}from"@medplum/core";import{badRequest as X,getReferenceString as at,getStatus as Eo,isOk as pi,normalizeOperationOutcome as vo,notFound as ai,OperationOutcomeError as G,parseSearchRequest as ci}from"@medplum/core";var No=50,Io=8,bo=/urn(:|%3A)uuid(:|%3A)[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}/,ui="urn:uuid";async function li(e,t,n,r){return new An(n,t,r,e).run()}var An=class{constructor(t,n,r,i){this.router=t,this.repo=n,this.bundle=r,this.req=i,this.resolvedIdentities=Object.create(null)}async run(){let t=this.bundle.type;if(t!=="batch"&&t!=="transaction")throw new G(X("Unrecognized bundle type: "+t));let n=new Array(this.bundle.entry?.length??0),r=await this.preprocessBundle(n);if(!this.isTransaction())return this.processBatch(r,n);if(r.updates>No)throw new G(X("Transaction contains more update operations than allowed"));if(r.requiresStrongTransaction&&n.length>Io)throw new G(X("Transaction requires strict isolation but has too many entries"));return this.repo.withTransaction(()=>this.processBatch(r,n),{serializable:r.requiresStrongTransaction})}async preprocessBundle(t){let n=this.bundle.entry;if(!n?.length)throw new G(X("Missing bundle entries"));let r={transaction:[],batch:[],delete:[],create:[],update:[],patch:[],operation:[],"search-system":[],"search-type":[],read:[],vread:[],"history-system":[],"history-type":[],"history-instance":[]},i=new Set,o=!1,s=0;for(let c=0;c<n.length;c++){let p=n[c];if(!p.request?.method){t[c]=At(X("Missing Bundle entry request method",`Bundle.entry[${c}].request.method`));continue}let d=await this.preprocessEntry(p,c,i);if(d){if(!this.isTransaction()){t[c]=At(d);continue}throw new G(d)}let T=this.getRouteForEntry(p)?.data?.interaction;if(!T||!r[T])throw new G(X(`Invalid REST interaction in batch: ${p.request?.method} ${p.request?.url}`));T==="create"&&p.request?.ifNoneExist?o=!0:T==="update"?(p.request?.url.includes("?")&&(o=!0),s++):T==="delete"&&p.request?.url.includes("?")&&(o=!0),r[T].push(c)}let a=[];for(let c of Object.values(r))a.push(...c);return{ordering:a,requiresStrongTransaction:o,updates:s}}async preprocessEntry(t,n,r){if(!t.request?.url)return X("Missing Bundle entry request URL",`Bundle.entry[${n}].request.url`);let i;try{i=await this.resolveIdentity(t,`Bundle.entry[${n}]`)}catch(o){if(o instanceof G)return o.outcome;throw o}if(i&&(this.resolvedIdentities[i.placeholder]=i.reference,this.isTransaction())){if(r.has(i.reference))throw new G(X("Duplicate resource identity found in Bundle"));r.add(i.reference)}}async resolveIdentity(t,n){let i=this.getRouteForEntry(t)?.data?.interaction;if(!i)throw new G(ai);switch(i){case"create":return this.resolveCreateIdentity(t);case"delete":case"update":case"patch":return this.resolveModificationIdentity(t,n);default:return}}getRouteForEntry(t){return this.router.find(t.request?.method,t.request?.url??"")}async resolveCreateIdentity(t){if(!t.fullUrl?.startsWith(ui))return;let n=t.fullUrl;if(t.request?.ifNoneExist){let r=await this.repo.searchResources(ci(t.request.url+"?"+t.request.ifNoneExist));if(r.length===1)return{placeholder:n,reference:at(r[0])}}if(t.resource)return t.resource.id=this.repo.generateId(),{placeholder:n,reference:at(t.resource)}}async resolveModificationIdentity(t,n){if(!t.fullUrl?.startsWith(ui))return;let r=t.fullUrl;if(t.request?.url?.includes("?")){let i=t.request.method,o=ci(t.request.url);o.count=2,o.offset=0,o.sortRules=void 0;let[s,a]=await this.repo.searchResources(o);if(!s)switch(i){case"DELETE":return;case"PUT":if(t.resource){if(t.resource.id)throw new G(X("Cannot provide ID for create by update"));return t.resource.id=this.repo.generateId(),{placeholder:r,reference:at(t.resource)}}return;default:throw new G(X(`Conditional ${t.request.method} did not match any resources`,n+".request.url"))}if(a)throw new G(X(`Conditional ${t.request.method} matched multiple resources`,n+".request.url"));let c=at(s);return t.request.url=c,t.resource&&(t.resource.id=s.id),{placeholder:r,reference:c}}if(t.request?.url.includes("/"))return{placeholder:r,reference:t.request.url}}async processBatch(t,n){let r=this.bundle.type,i=this.bundle.entry;if(!i)throw new G(X("Missing bundle entry"));let o={type:"batch",bundleType:r,count:i.length,size:JSON.stringify(this.bundle).length};this.router.dispatchEvent(o);let s=0;for(let c of t.ordering){let p=i[c],l=this.rewriteIdsInObject(p);try{n[c]=await this.processBatchEntry(l)}catch(d){if(this.isTransaction())throw d;s++,n[c]=At(vo(d));continue}}let a={type:"batch",bundleType:r,errors:s};return this.router.dispatchEvent(a),{resourceType:"Bundle",type:`${r}-response`,entry:n}}async processBatchEntry(t){let n=this.getRouteForEntry(t);if(!n)throw new G(ai);let r=this.parseBatchRequest(t,n),[i,o]=await n.handler(r,this.repo,this.router,{batch:!0});if(!pi(i)&&this.isTransaction())throw new G(i);return At(i,o)}parseBatchRequest(t,n){let r=t.request,i=Object.create(null);r.ifNoneExist&&(i["if-none-exist"]=r.ifNoneExist),r.ifMatch&&(i["if-match"]=r.ifMatch),r.ifNoneMatch&&(i["if-none-match"]=r.ifNoneMatch),r.ifModifiedSince&&(i["if-modified-since"]=r.ifModifiedSince);let o;return r.method==="PATCH"?o=this.parsePatchBody(t):o=t.resource,{method:r.method,url:n?.query?r.url.slice(0,r.url.indexOf("?")):r.url,pathname:"",params:n?.params??Object.create(null),query:n?.query??Object.create(null),body:o,headers:i}}parsePatchBody(t){let n=t.resource,r;if(n?.resourceType==="Binary"){if(!n.data)throw new G(X("Missing entry.resource.data"));r=JSON.parse(Buffer.from(n.data,"base64").toString("utf8"))}else if(n?.resourceType==="Parameters"){if(n.parameter){r=[];for(let i of n.parameter)if(i.name==="operation"){let o=this.parsePatchParameter(i);r.push(o)}}}else throw new G(X("Patch entry must include a Binary or Parameters resource"));if(!Array.isArray(r))throw new G(X("Decoded PATCH body must be an array"));return this.rewriteIdsInArray(r)}parsePatchParameter(t){let n=t.part?.find(i=>i.name==="op")?.valueCode;if(!n)throw new G(X("PATCH Parameters missing op"));let r={op:n};switch(n){case"add":case"replace":case"test":for(let i of t.part)i.name==="path"?r.path=i.valueString:i.name==="value"&&(r.value=JSON.parse(i.valueString??""));break;case"copy":case"move":for(let i of t.part)i.name==="path"?r.path=i.valueString:i.name==="from"&&(r.from=i.valueString);break;case"remove":r.path=t.part?.find(i=>i.name==="path")?.valueString;break}return r}rewriteIds(t){return Array.isArray(t)?this.rewriteIdsInArray(t):typeof t=="string"?this.rewriteIdsInString(t):typeof t=="object"&&t!==null?this.rewriteIdsInObject(t):t}rewriteIdsInArray(t){return t.map(n=>this.rewriteIds(n))}rewriteIdsInObject(t){return Object.fromEntries(Object.entries(t).map(([n,r])=>[n,this.rewriteIds(r)]))}rewriteIdsInString(t){let n=bo.exec(t)?.[0];if(!n)return t;let r=n.replaceAll("%3A",":"),i=this.resolvedIdentities[r];return i?t.replaceAll(n,i):t}isTransaction(){return this.bundle.type==="transaction"&&!!this.req.config?.transactions}};function At(e,t){return{response:{outcome:e,status:Eo(e).toString(),location:pi(e)&&t?.id?at(t):void 0},resource:t}}import{allOk as tc,badRequest as Dt,ContentType as nc,deepClone as yo,DEFAULT_SEARCH_COUNT as rc,forbidden as ic,getResourceTypes as ho,LRUCache as oc,normalizeOperationOutcome as sc,OperationOutcomeError as Ln}from"@medplum/core";import ac from"dataloader";function R(e,t){if(!!!e)throw new Error(t)}function se(e){return typeof e?.then=="function"}function j(e){return typeof e=="object"&&e!==null}function C(e,t){if(!!!e)throw new Error(t??"Unexpected invariant triggered.")}var Ro=/\r\n|[\n\r]/g;function Ge(e,t){let n=0,r=1;for(let i of e.body.matchAll(Ro)){if(typeof i.index=="number"||C(!1),i.index>=t)break;n=i.index+i[0].length,r+=1}return{line:r,column:t+1-n}}function Fn(e){return Ft(e.source,Ge(e.source,e.start))}function Ft(e,t){let n=e.locationOffset.column-1,r="".padStart(n)+e.body,i=t.line-1,o=e.locationOffset.line-1,s=t.line+o,a=t.line===1?n:0,c=t.column+a,p=`${e.name}:${s}:${c}
1
+ import{badRequest as X,getReferenceString as at,getStatus as Eo,isOk as pi,normalizeOperationOutcome as vo,notFound as ai,OperationOutcomeError as G,parseSearchRequest as ci}from"@medplum/core";var No=50,Io=8,bo=/urn(:|%3A)uuid(:|%3A)[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}/,ui="urn:uuid";async function li(e,t,n,r){return new An(n,t,r,e).run()}var An=class{constructor(t,n,r,i){this.router=t,this.repo=n,this.bundle=r,this.req=i,this.resolvedIdentities=Object.create(null)}async run(){let t=this.bundle.type;if(t!=="batch"&&t!=="transaction")throw new G(X("Unrecognized bundle type: "+t));let n=new Array(this.bundle.entry?.length??0),r=await this.preprocessBundle(n);if(!this.isTransaction())return this.processBatch(r,n);if(r.updates>No)throw new G(X("Transaction contains more update operations than allowed"));if(r.requiresStrongTransaction&&n.length>Io)throw new G(X("Transaction requires strict isolation but has too many entries"));return this.repo.withTransaction(()=>this.processBatch(r,n),{serializable:r.requiresStrongTransaction})}async preprocessBundle(t){let n=this.bundle.entry;if(!n?.length)throw new G(X("Missing bundle entries"));let r={transaction:[],batch:[],delete:[],create:[],update:[],patch:[],operation:[],"search-system":[],"search-type":[],read:[],vread:[],"history-system":[],"history-type":[],"history-instance":[]},i=new Set,o=!1,s=0;for(let c=0;c<n.length;c++){let p=n[c];if(!p.request?.method){t[c]=At(X("Missing Bundle entry request method",`Bundle.entry[${c}].request.method`));continue}let d=await this.preprocessEntry(p,c,i);if(d){if(!this.isTransaction()){t[c]=At(d);continue}throw new G(d)}let T=this.getRouteForEntry(p)?.data?.interaction;if(!T||!r[T])throw new G(X(`Invalid REST interaction in batch: ${p.request?.method} ${p.request?.url}`));T==="create"&&p.request?.ifNoneExist?o=!0:T==="update"?(p.request?.url.includes("?")&&(o=!0),s++):T==="delete"&&p.request?.url.includes("?")&&(o=!0),r[T].push(c)}let a=[];for(let c of Object.values(r))a.push(...c);return{ordering:a,requiresStrongTransaction:o,updates:s}}async preprocessEntry(t,n,r){if(!t.request?.url)return X("Missing Bundle entry request URL",`Bundle.entry[${n}].request.url`);let i;try{i=await this.resolveIdentity(t,`Bundle.entry[${n}]`)}catch(o){if(o instanceof G)return o.outcome;throw o}if(i&&(this.resolvedIdentities[i.placeholder]=i.reference,this.isTransaction())){if(r.has(i.reference))throw new G(X("Duplicate resource identity found in Bundle"));r.add(i.reference)}}async resolveIdentity(t,n){let i=this.getRouteForEntry(t)?.data?.interaction;if(!i)throw new G(ai);switch(i){case"create":return this.resolveCreateIdentity(t);case"delete":case"update":case"patch":return this.resolveModificationIdentity(t,n);default:return}}getRouteForEntry(t){return this.router.find(t.request?.method,t.request?.url??"")}async resolveCreateIdentity(t){if(!t.fullUrl?.startsWith(ui))return;let n=t.fullUrl;if(t.request?.ifNoneExist){let r=await this.repo.searchResources(ci(t.request.url+"?"+t.request.ifNoneExist));if(r.length===1)return{placeholder:n,reference:at(r[0])}}if(t.resource)return t.resource.id=this.repo.generateId(),{placeholder:n,reference:at(t.resource)}}async resolveModificationIdentity(t,n){if(!t.fullUrl?.startsWith(ui))return;let r=t.fullUrl;if(t.request?.url?.includes("?")){let i=t.request.method,o=ci(t.request.url);o.count=2,o.offset=0,o.sortRules=void 0;let[s,a]=await this.repo.searchResources(o);if(!s)switch(i){case"DELETE":return;case"PUT":if(t.resource){if(t.resource.id)throw new G(X("Cannot provide ID for create by update"));return t.resource.id=this.repo.generateId(),{placeholder:r,reference:at(t.resource)}}return;default:throw new G(X(`Conditional ${t.request.method} did not match any resources`,n+".request.url"))}if(a)throw new G(X(`Conditional ${t.request.method} matched multiple resources`,n+".request.url"));let c=at(s);return t.request.url=c,t.resource&&(t.resource.id=s.id),{placeholder:r,reference:c}}if(t.request?.url.includes("/"))return{placeholder:r,reference:t.request.url}}async processBatch(t,n){let r=this.bundle.type,i=this.bundle.entry;if(!i)throw new G(X("Missing bundle entry"));let o={type:"batch",bundleType:r,count:i.length,size:JSON.stringify(this.bundle).length};this.router.dispatchEvent(o);let s=0;for(let c of t.ordering){let p=i[c],l=this.rewriteIdsInObject(p);try{n[c]=await this.processBatchEntry(l)}catch(d){if(this.isTransaction())throw d;s++,n[c]=At(vo(d));continue}}let a={type:"batch",bundleType:r,errors:s};return this.router.dispatchEvent(a),{resourceType:"Bundle",type:`${r}-response`,entry:n}}async processBatchEntry(t){let n=this.getRouteForEntry(t);if(!n)throw new G(ai);let r=this.parseBatchRequest(t,n),[i,o]=await n.handler(r,this.repo,this.router,{batch:!0});if(!pi(i)&&this.isTransaction())throw new G(i);return At(i,o)}parseBatchRequest(t,n){let r=t.request,i=Object.create(null);r.ifNoneExist&&(i["if-none-exist"]=r.ifNoneExist),r.ifMatch&&(i["if-match"]=r.ifMatch),r.ifNoneMatch&&(i["if-none-match"]=r.ifNoneMatch),r.ifModifiedSince&&(i["if-modified-since"]=r.ifModifiedSince);let o;return r.method==="PATCH"?o=this.parsePatchBody(t):o=t.resource,{method:r.method,url:n?.query?r.url.slice(0,r.url.indexOf("?")):r.url,pathname:"",params:n?.params??Object.create(null),query:n?.query??Object.create(null),body:o,headers:i}}parsePatchBody(t){let n=t.resource,r;if(n?.resourceType==="Binary"){if(!n.data)throw new G(X("Missing entry.resource.data"));r=JSON.parse(Buffer.from(n.data,"base64").toString("utf8"))}else if(n?.resourceType==="Parameters"){if(n.parameter){r=[];for(let i of n.parameter)if(i.name==="operation"){let o=this.parsePatchParameter(i);r.push(o)}}}else throw new G(X("Patch entry must include a Binary or Parameters resource"));if(!Array.isArray(r))throw new G(X("Decoded PATCH body must be an array"));return this.rewriteIdsInArray(r)}parsePatchParameter(t){let n=t.part?.find(i=>i.name==="op")?.valueCode;if(!n)throw new G(X("PATCH Parameters missing op"));let r={op:n};switch(n){case"add":case"replace":case"test":for(let i of t.part)i.name==="path"?r.path=i.valueString:i.name==="value"&&(r.value=JSON.parse(i.valueString??""));break;case"copy":case"move":for(let i of t.part)i.name==="path"?r.path=i.valueString:i.name==="from"&&(r.from=i.valueString);break;case"remove":r.path=t.part?.find(i=>i.name==="path")?.valueString;break}return r}rewriteIds(t){return Array.isArray(t)?this.rewriteIdsInArray(t):typeof t=="string"?this.rewriteIdsInString(t):typeof t=="object"&&t!==null?this.rewriteIdsInObject(t):t}rewriteIdsInArray(t){return t.map(n=>this.rewriteIds(n))}rewriteIdsInObject(t){return Object.fromEntries(Object.entries(t).map(([n,r])=>[n,this.rewriteIds(r)]))}rewriteIdsInString(t){let n=bo.exec(t)?.[0];if(!n)return t;let r=n.replaceAll("%3A",":"),i=this.resolvedIdentities[r];return i?t.replaceAll(n,i):t}isTransaction(){return this.bundle.type==="transaction"&&!!this.req.config?.transactions}};function At(e,t){return{response:{outcome:e,status:Eo(e).toString(),location:pi(e)&&t?.id?at(t):void 0},resource:t}}import{EventTarget as wc,OperationOutcomeError as Dc,allOk as Ee,badRequest as _e,created as Ac,normalizeOperationOutcome as Fc,notFound as kc,parseSearchRequest as ot,singularize as Cc}from"@medplum/core";import{allOk as tc,badRequest as Dt,ContentType as nc,deepClone as yo,DEFAULT_SEARCH_COUNT as rc,forbidden as ic,getResourceTypes as ho,LRUCache as oc,normalizeOperationOutcome as sc,OperationOutcomeError as Ln}from"@medplum/core";import ac from"dataloader";function R(e,t){if(!!!e)throw new Error(t)}function se(e){return typeof e?.then=="function"}function j(e){return typeof e=="object"&&e!==null}function C(e,t){if(!!!e)throw new Error(t??"Unexpected invariant triggered.")}var Ro=/\r\n|[\n\r]/g;function Ge(e,t){let n=0,r=1;for(let i of e.body.matchAll(Ro)){if(typeof i.index=="number"||C(!1),i.index>=t)break;n=i.index+i[0].length,r+=1}return{line:r,column:t+1-n}}function Fn(e){return Ft(e.source,Ge(e.source,e.start))}function Ft(e,t){let n=e.locationOffset.column-1,r="".padStart(n)+e.body,i=t.line-1,o=e.locationOffset.line-1,s=t.line+o,a=t.line===1?n:0,c=t.column+a,p=`${e.name}:${s}:${c}
2
2
  `,l=r.split(/\r\n|[\n\r]/g),d=l[i];if(d.length>120){let h=Math.floor(c/80),T=c%80,g=[];for(let D=0;D<d.length;D+=80)g.push(d.slice(D,D+80));return p+fi([[`${s} |`,g[0]],...g.slice(1,h+1).map(D=>["|",D]),["|","^".padStart(T)],["|",g[h+1]]])}return p+fi([[`${s-1} |`,l[i-1]],[`${s} |`,d],["|","^".padStart(c)],[`${s+1} |`,l[i+1]]])}function fi(e){let t=e.filter(([r,i])=>i!==void 0),n=Math.max(...t.map(([r])=>r.length));return t.map(([r,i])=>r.padStart(n)+(i?" "+i:"")).join(`
3
3
  `)}function Oo(e){let t=e[0];return t==null||"kind"in t||"length"in t?{nodes:t,source:e[1],positions:e[2],path:e[3],originalError:e[4],extensions:e[5]}:t}var f=class e extends Error{constructor(t,...n){var r,i,o;let{nodes:s,source:a,positions:c,path:p,originalError:l,extensions:d}=Oo(n);super(t),this.name="GraphQLError",this.path=p??void 0,this.originalError=l??void 0,this.nodes=di(Array.isArray(s)?s:s?[s]:void 0);let h=di((r=this.nodes)===null||r===void 0?void 0:r.map(g=>g.loc).filter(g=>g!=null));this.source=a??(h==null||(i=h[0])===null||i===void 0?void 0:i.source),this.positions=c??h?.map(g=>g.start),this.locations=c&&a?c.map(g=>Ge(a,g)):h?.map(g=>Ge(g.source,g.start));let T=j(l?.extensions)?l?.extensions:void 0;this.extensions=(o=d??T)!==null&&o!==void 0?o:Object.create(null),Object.defineProperties(this,{message:{writable:!0,enumerable:!0},name:{enumerable:!1},nodes:{enumerable:!1},source:{enumerable:!1},positions:{enumerable:!1},originalError:{enumerable:!1}}),l!=null&&l.stack?Object.defineProperty(this,"stack",{value:l.stack,writable:!0,configurable:!0}):Error.captureStackTrace?Error.captureStackTrace(this,e):Object.defineProperty(this,"stack",{value:Error().stack,writable:!0,configurable:!0})}get[Symbol.toStringTag](){return"GraphQLError"}toString(){let t=this.message;if(this.nodes)for(let n of this.nodes)n.loc&&(t+=`
4
4
 
@@ -50,6 +50,6 @@ spurious results.`)}}return!1};var qe=class{constructor(t,n="GraphQL request",r=
50
50
 
51
51
  In some cases, you need to provide options to alter GraphQL's execution behavior in ways field arguments will not suffice, such as conditionally including or skipping a field. Directives provide this by describing additional information to the executor.`,fields:()=>({name:{type:new I(v),resolve:e=>e.name},description:{type:v,resolve:e=>e.description},isRepeatable:{type:new I(V),resolve:e=>e.isRepeatable},locations:{type:new I(new A(new I(Hn))),resolve:e=>e.locations},args:{type:new I(new A(new I(It))),args:{includeDeprecated:{type:V,defaultValue:!1}},resolve(e,{includeDeprecated:t}){return t?e.args:e.args.filter(n=>n.deprecationReason==null)}}})}),Hn=new ve({name:"__DirectiveLocation",description:"A Directive can be adjacent to many parts of the GraphQL language, a __DirectiveLocation describes one such possible adjacencies.",values:{QUERY:{value:N.QUERY,description:"Location adjacent to a query operation."},MUTATION:{value:N.MUTATION,description:"Location adjacent to a mutation operation."},SUBSCRIPTION:{value:N.SUBSCRIPTION,description:"Location adjacent to a subscription operation."},FIELD:{value:N.FIELD,description:"Location adjacent to a field."},FRAGMENT_DEFINITION:{value:N.FRAGMENT_DEFINITION,description:"Location adjacent to a fragment definition."},FRAGMENT_SPREAD:{value:N.FRAGMENT_SPREAD,description:"Location adjacent to a fragment spread."},INLINE_FRAGMENT:{value:N.INLINE_FRAGMENT,description:"Location adjacent to an inline fragment."},VARIABLE_DEFINITION:{value:N.VARIABLE_DEFINITION,description:"Location adjacent to a variable definition."},SCHEMA:{value:N.SCHEMA,description:"Location adjacent to a schema definition."},SCALAR:{value:N.SCALAR,description:"Location adjacent to a scalar definition."},OBJECT:{value:N.OBJECT,description:"Location adjacent to an object type definition."},FIELD_DEFINITION:{value:N.FIELD_DEFINITION,description:"Location adjacent to a field definition."},ARGUMENT_DEFINITION:{value:N.ARGUMENT_DEFINITION,description:"Location adjacent to an argument definition."},INTERFACE:{value:N.INTERFACE,description:"Location adjacent to an interface definition."},UNION:{value:N.UNION,description:"Location adjacent to a union definition."},ENUM:{value:N.ENUM,description:"Location adjacent to an enum definition."},ENUM_VALUE:{value:N.ENUM_VALUE,description:"Location adjacent to an enum value definition."},INPUT_OBJECT:{value:N.INPUT_OBJECT,description:"Location adjacent to an input object type definition."},INPUT_FIELD_DEFINITION:{value:N.INPUT_FIELD_DEFINITION,description:"Location adjacent to an input object field definition."}}}),pe=new Q({name:"__Type",description:"The fundamental unit of any GraphQL Schema is the type. There are many kinds of types in GraphQL as represented by the `__TypeKind` enum.\n\nDepending on the kind of a type, certain fields describe information about that type. Scalar types provide no information beyond a name, description and optional `specifiedByURL`, while Enum types provide their values. Object and Interface types provide the fields they describe. Abstract types, Union and Interface, provide the Object types possible at runtime. List and NonNull types compose other types.",fields:()=>({kind:{type:new I(Xn),resolve(e){if(he(e))return B.SCALAR;if(O(e))return B.OBJECT;if(_(e))return B.INTERFACE;if(Y(e))return B.UNION;if($(e))return B.ENUM;if(L(e))return B.INPUT_OBJECT;if(w(e))return B.LIST;if(b(e))return B.NON_NULL;C(!1,`Unexpected type: "${y(e)}".`)}},name:{type:v,resolve:e=>"name"in e?e.name:void 0},description:{type:v,resolve:e=>"description"in e?e.description:void 0},specifiedByURL:{type:v,resolve:e=>"specifiedByURL"in e?e.specifiedByURL:void 0},fields:{type:new A(new I(Jn)),args:{includeDeprecated:{type:V,defaultValue:!1}},resolve(e,{includeDeprecated:t}){if(O(e)||_(e)){let n=Object.values(e.getFields());return t?n:n.filter(r=>r.deprecationReason==null)}}},interfaces:{type:new A(new I(pe)),resolve(e){if(O(e)||_(e))return e.getInterfaces()}},possibleTypes:{type:new A(new I(pe)),resolve(e,t,n,{schema:r}){if(ne(e))return r.getPossibleTypes(e)}},enumValues:{type:new A(new I(zn)),args:{includeDeprecated:{type:V,defaultValue:!1}},resolve(e,{includeDeprecated:t}){if($(e)){let n=e.getValues();return t?n:n.filter(r=>r.deprecationReason==null)}}},inputFields:{type:new A(new I(It)),args:{includeDeprecated:{type:V,defaultValue:!1}},resolve(e,{includeDeprecated:t}){if(L(e)){let n=Object.values(e.getFields());return t?n:n.filter(r=>r.deprecationReason==null)}}},ofType:{type:pe,resolve:e=>"ofType"in e?e.ofType:void 0},isOneOf:{type:V,resolve:e=>{if(L(e))return e.isOneOf}}})}),Jn=new Q({name:"__Field",description:"Object and Interface types are described by a list of Fields, each of which has a name, potentially a list of arguments, and a return type.",fields:()=>({name:{type:new I(v),resolve:e=>e.name},description:{type:v,resolve:e=>e.description},args:{type:new I(new A(new I(It))),args:{includeDeprecated:{type:V,defaultValue:!1}},resolve(e,{includeDeprecated:t}){return t?e.args:e.args.filter(n=>n.deprecationReason==null)}},type:{type:new I(pe),resolve:e=>e.type},isDeprecated:{type:new I(V),resolve:e=>e.deprecationReason!=null},deprecationReason:{type:v,resolve:e=>e.deprecationReason}})}),It=new Q({name:"__InputValue",description:"Arguments provided to Fields or Directives and the input fields of an InputObject are represented as Input Values which describe their type and optionally a default value.",fields:()=>({name:{type:new I(v),resolve:e=>e.name},description:{type:v,resolve:e=>e.description},type:{type:new I(pe),resolve:e=>e.type},defaultValue:{type:v,description:"A GraphQL-formatted string representing the default value for this input value.",resolve(e){let{type:t,defaultValue:n}=e,r=et(n,t);return r?x(r):null}},isDeprecated:{type:new I(V),resolve:e=>e.deprecationReason!=null},deprecationReason:{type:v,resolve:e=>e.deprecationReason}})}),zn=new Q({name:"__EnumValue",description:"One possible value for a given Enum. Enum values are unique values, not a placeholder for a string or numeric value. However an Enum value is returned in a JSON response as a string.",fields:()=>({name:{type:new I(v),resolve:e=>e.name},description:{type:v,resolve:e=>e.description},isDeprecated:{type:new I(V),resolve:e=>e.deprecationReason!=null},deprecationReason:{type:v,resolve:e=>e.deprecationReason}})}),B;(function(e){e.SCALAR="SCALAR",e.OBJECT="OBJECT",e.INTERFACE="INTERFACE",e.UNION="UNION",e.ENUM="ENUM",e.INPUT_OBJECT="INPUT_OBJECT",e.LIST="LIST",e.NON_NULL="NON_NULL"})(B||(B={}));var Xn=new ve({name:"__TypeKind",description:"An enum describing what kind of type a given `__Type` is.",values:{SCALAR:{value:B.SCALAR,description:"Indicates this type is a scalar."},OBJECT:{value:B.OBJECT,description:"Indicates this type is an object. `fields` and `interfaces` are valid fields."},INTERFACE:{value:B.INTERFACE,description:"Indicates this type is an interface. `fields`, `interfaces`, and `possibleTypes` are valid fields."},UNION:{value:B.UNION,description:"Indicates this type is a union. `possibleTypes` is a valid field."},ENUM:{value:B.ENUM,description:"Indicates this type is an enum. `enumValues` is a valid field."},INPUT_OBJECT:{value:B.INPUT_OBJECT,description:"Indicates this type is an input object. `inputFields` is a valid field."},LIST:{value:B.LIST,description:"Indicates this type is a list. `ofType` is a valid field."},NON_NULL:{value:B.NON_NULL,description:"Indicates this type is a non-null. `ofType` is a valid field."}}}),Ae={name:"__schema",type:new I(Nt),description:"Access the current type schema of this server.",args:[],resolve:(e,t,n,{schema:r})=>r,deprecationReason:void 0,extensions:Object.create(null),astNode:void 0},Fe={name:"__type",type:pe,description:"Request the type information of a single type.",args:[{name:"name",description:void 0,type:new I(v),defaultValue:void 0,deprecationReason:void 0,extensions:Object.create(null),astNode:void 0}],resolve:(e,{name:t},n,{schema:r})=>r.getType(t),deprecationReason:void 0,extensions:Object.create(null),astNode:void 0},ke={name:"__typename",type:new I(v),description:"The name of the current Object type at runtime.",args:[],resolve:(e,t,n,{parentType:r})=>r.name,deprecationReason:void 0,extensions:Object.create(null),astNode:void 0},Wt=Object.freeze([Nt,Yn,Hn,pe,Jn,It,zn,Xn]);function Kn(e){return Wt.some(({name:t})=>e.name===t)}function Wn(e){return Z(e,Ce)}function Zt(e){if(!Wn(e))throw new Error(`Expected ${y(e)} to be a GraphQL schema.`);return e}var Ce=class{constructor(t){var n,r;this.__validationErrors=t.assumeValid===!0?[]:void 0,j(t)||R(!1,"Must provide configuration object."),!t.types||Array.isArray(t.types)||R(!1,`"types" must be Array if provided but got: ${y(t.types)}.`),!t.directives||Array.isArray(t.directives)||R(!1,`"directives" must be Array if provided but got: ${y(t.directives)}.`),this.description=t.description,this.extensions=te(t.extensions),this.astNode=t.astNode,this.extensionASTNodes=(n=t.extensionASTNodes)!==null&&n!==void 0?n:[],this._queryType=t.query,this._mutationType=t.mutation,this._subscriptionType=t.subscription,this._directives=(r=t.directives)!==null&&r!==void 0?r:Te;let i=new Set(t.types);if(t.types!=null)for(let o of t.types)i.delete(o),ge(o,i);this._queryType!=null&&ge(this._queryType,i),this._mutationType!=null&&ge(this._mutationType,i),this._subscriptionType!=null&&ge(this._subscriptionType,i);for(let o of this._directives)if(vt(o))for(let s of o.args)ge(s.type,i);ge(Nt,i),this._typeMap=Object.create(null),this._subTypeMap=Object.create(null),this._implementationsMap=Object.create(null);for(let o of i){if(o==null)continue;let s=o.name;if(s||R(!1,"One of the provided types for building the Schema is missing a name."),this._typeMap[s]!==void 0)throw new Error(`Schema must contain uniquely named types but contains multiple types named "${s}".`);if(this._typeMap[s]=o,_(o)){for(let a of o.getInterfaces())if(_(a)){let c=this._implementationsMap[a.name];c===void 0&&(c=this._implementationsMap[a.name]={objects:[],interfaces:[]}),c.interfaces.push(o)}}else if(O(o)){for(let a of o.getInterfaces())if(_(a)){let c=this._implementationsMap[a.name];c===void 0&&(c=this._implementationsMap[a.name]={objects:[],interfaces:[]}),c.objects.push(o)}}}}get[Symbol.toStringTag](){return"GraphQLSchema"}getQueryType(){return this._queryType}getMutationType(){return this._mutationType}getSubscriptionType(){return this._subscriptionType}getRootType(t){switch(t){case F.QUERY:return this.getQueryType();case F.MUTATION:return this.getMutationType();case F.SUBSCRIPTION:return this.getSubscriptionType()}}getTypeMap(){return this._typeMap}getType(t){return this.getTypeMap()[t]}getPossibleTypes(t){return Y(t)?t.getTypes():this.getImplementations(t).objects}getImplementations(t){let n=this._implementationsMap[t.name];return n??{objects:[],interfaces:[]}}isSubType(t,n){let r=this._subTypeMap[t.name];if(r===void 0){if(r=Object.create(null),Y(t))for(let i of t.getTypes())r[i.name]=!0;else{let i=this.getImplementations(t);for(let o of i.objects)r[o.name]=!0;for(let o of i.interfaces)r[o.name]=!0}this._subTypeMap[t.name]=r}return r[n.name]!==void 0}getDirectives(){return this._directives}getDirective(t){return this.getDirectives().find(n=>n.name===t)}toConfig(){return{description:this.description,query:this.getQueryType(),mutation:this.getMutationType(),subscription:this.getSubscriptionType(),types:Object.values(this.getTypeMap()),directives:this.getDirectives(),extensions:this.extensions,astNode:this.astNode,extensionASTNodes:this.extensionASTNodes,assumeValid:this.__validationErrors!==void 0}}};function ge(e,t){let n=q(e);if(!t.has(n)){if(t.add(n),Y(n))for(let r of n.getTypes())ge(r,t);else if(O(n)||_(n)){for(let r of n.getInterfaces())ge(r,t);for(let r of Object.values(n.getFields())){ge(r.type,t);for(let i of r.args)ge(i.type,t)}}else if(L(n))for(let r of Object.values(n.getFields()))ge(r.type,t)}return t}function Pi(e){if(Zt(e),e.__validationErrors)return e.__validationErrors;let t=new er(e);Ko(t),Wo(t),Zo(t);let n=t.getErrors();return e.__validationErrors=n,n}function Rt(e){let t=Pi(e);if(t.length!==0)throw new Error(t.map(n=>n.message).join(`
52
52
 
53
- `))}var er=class{constructor(t){this._errors=[],this.schema=t}reportError(t,n){let r=Array.isArray(n)?n.filter(Boolean):n;this._errors.push(new f(t,{nodes:r}))}getErrors(){return this._errors}};function Ko(e){let t=e.schema,n=t.getQueryType();if(!n)e.reportError("Query root type must be provided.",t.astNode);else if(!O(n)){var r;e.reportError(`Query root type must be Object type, it cannot be ${y(n)}.`,(r=Zn(t,F.QUERY))!==null&&r!==void 0?r:n.astNode)}let i=t.getMutationType();if(i&&!O(i)){var o;e.reportError(`Mutation root type must be Object type if provided, it cannot be ${y(i)}.`,(o=Zn(t,F.MUTATION))!==null&&o!==void 0?o:i.astNode)}let s=t.getSubscriptionType();if(s&&!O(s)){var a;e.reportError(`Subscription root type must be Object type if provided, it cannot be ${y(s)}.`,(a=Zn(t,F.SUBSCRIPTION))!==null&&a!==void 0?a:s.astNode)}}function Zn(e,t){var n;return(n=[e.astNode,...e.extensionASTNodes].flatMap(r=>{var i;return(i=r?.operationTypes)!==null&&i!==void 0?i:[]}).find(r=>r.operation===t))===null||n===void 0?void 0:n.type}function Wo(e){for(let n of e.schema.getDirectives()){if(!vt(n)){e.reportError(`Expected directive but got: ${y(n)}.`,n?.astNode);continue}Me(e,n),n.locations.length===0&&e.reportError(`Directive @${n.name} must include 1 or more locations.`,n.astNode);for(let r of n.args)if(Me(e,r),H(r.type)||e.reportError(`The type of @${n.name}(${r.name}:) must be Input Type but got: ${y(r.type)}.`,r.astNode),Ie(r)&&r.deprecationReason!=null){var t;e.reportError(`Required argument @${n.name}(${r.name}:) cannot be deprecated.`,[tr(r.astNode),(t=r.astNode)===null||t===void 0?void 0:t.type])}}}function Me(e,t){t.name.startsWith("__")&&e.reportError(`Name "${t.name}" must not begin with "__", which is reserved by GraphQL introspection.`,t.astNode)}function Zo(e){let t=ss(e),n=e.schema.getTypeMap();for(let r of Object.values(n)){if(!Bt(r)){e.reportError(`Expected GraphQL named type but got: ${y(r)}.`,r.astNode);continue}Kn(r)||Me(e,r),O(r)||_(r)?(ki(e,r),Ci(e,r)):Y(r)?ns(e,r):$(r)?rs(e,r):L(r)&&(is(e,r),t(r))}}function ki(e,t){let n=Object.values(t.getFields());n.length===0&&e.reportError(`Type ${t.name} must define one or more fields.`,[t.astNode,...t.extensionASTNodes]);for(let s of n){if(Me(e,s),!Ne(s.type)){var r;e.reportError(`The type of ${t.name}.${s.name} must be Output Type but got: ${y(s.type)}.`,(r=s.astNode)===null||r===void 0?void 0:r.type)}for(let a of s.args){let c=a.name;if(Me(e,a),!H(a.type)){var i;e.reportError(`The type of ${t.name}.${s.name}(${c}:) must be Input Type but got: ${y(a.type)}.`,(i=a.astNode)===null||i===void 0?void 0:i.type)}if(Ie(a)&&a.deprecationReason!=null){var o;e.reportError(`Required argument ${t.name}.${s.name}(${c}:) cannot be deprecated.`,[tr(a.astNode),(o=a.astNode)===null||o===void 0?void 0:o.type])}}}}function Ci(e,t){let n=Object.create(null);for(let r of t.getInterfaces()){if(!_(r)){e.reportError(`Type ${y(t)} must only implement Interface types, it cannot implement ${y(r)}.`,bt(t,r));continue}if(t===r){e.reportError(`Type ${t.name} cannot implement itself because it would create a circular reference.`,bt(t,r));continue}if(n[r.name]){e.reportError(`Type ${t.name} can only implement ${r.name} once.`,bt(t,r));continue}n[r.name]=!0,ts(e,t,r),es(e,t,r)}}function es(e,t,n){let r=t.getFields();for(let c of Object.values(n.getFields())){let p=c.name,l=r[p];if(!l){e.reportError(`Interface field ${n.name}.${p} expected but ${t.name} does not provide it.`,[c.astNode,t.astNode,...t.extensionASTNodes]);continue}if(!Re(e.schema,l.type,c.type)){var i,o;e.reportError(`Interface field ${n.name}.${p} expects type ${y(c.type)} but ${t.name}.${p} is type ${y(l.type)}.`,[(i=c.astNode)===null||i===void 0?void 0:i.type,(o=l.astNode)===null||o===void 0?void 0:o.type])}for(let d of c.args){let h=d.name,T=l.args.find(g=>g.name===h);if(!T){e.reportError(`Interface field argument ${n.name}.${p}(${h}:) expected but ${t.name}.${p} does not provide it.`,[d.astNode,l.astNode]);continue}if(!Ht(d.type,T.type)){var s,a;e.reportError(`Interface field argument ${n.name}.${p}(${h}:) expects type ${y(d.type)} but ${t.name}.${p}(${h}:) is type ${y(T.type)}.`,[(s=d.astNode)===null||s===void 0?void 0:s.type,(a=T.astNode)===null||a===void 0?void 0:a.type])}}for(let d of l.args){let h=d.name;!c.args.find(g=>g.name===h)&&Ie(d)&&e.reportError(`Object field ${t.name}.${p} includes required argument ${h} that is missing from the Interface field ${n.name}.${p}.`,[d.astNode,c.astNode])}}}function ts(e,t,n){let r=t.getInterfaces();for(let i of n.getInterfaces())r.includes(i)||e.reportError(i===t?`Type ${t.name} cannot implement ${n.name} because it would create a circular reference.`:`Type ${t.name} must implement ${i.name} because it is implemented by ${n.name}.`,[...bt(n,i),...bt(t,n)])}function ns(e,t){let n=t.getTypes();n.length===0&&e.reportError(`Union type ${t.name} must define one or more member types.`,[t.astNode,...t.extensionASTNodes]);let r=Object.create(null);for(let i of n){if(r[i.name]){e.reportError(`Union type ${t.name} can only include type ${i.name} once.`,Mi(t,i.name));continue}r[i.name]=!0,O(i)||e.reportError(`Union type ${t.name} can only include Object types, it cannot include ${y(i)}.`,Mi(t,String(i)))}}function rs(e,t){let n=t.getValues();n.length===0&&e.reportError(`Enum type ${t.name} must define one or more values.`,[t.astNode,...t.extensionASTNodes]);for(let r of n)Me(e,r)}function is(e,t){let n=Object.values(t.getFields());n.length===0&&e.reportError(`Input Object type ${t.name} must define one or more fields.`,[t.astNode,...t.extensionASTNodes]);for(let o of n){if(Me(e,o),!H(o.type)){var r;e.reportError(`The type of ${t.name}.${o.name} must be Input Type but got: ${y(o.type)}.`,(r=o.astNode)===null||r===void 0?void 0:r.type)}if(We(o)&&o.deprecationReason!=null){var i;e.reportError(`Required input field ${t.name}.${o.name} cannot be deprecated.`,[tr(o.astNode),(i=o.astNode)===null||i===void 0?void 0:i.type])}t.isOneOf&&os(t,o,e)}}function os(e,t,n){if(b(t.type)){var r;n.reportError(`OneOf input field ${e.name}.${t.name} must be nullable.`,(r=t.astNode)===null||r===void 0?void 0:r.type)}t.defaultValue!==void 0&&n.reportError(`OneOf input field ${e.name}.${t.name} cannot have a default value.`,t.astNode)}function ss(e){let t=Object.create(null),n=[],r=Object.create(null);return i;function i(o){if(t[o.name])return;t[o.name]=!0,r[o.name]=n.length;let s=Object.values(o.getFields());for(let a of s)if(b(a.type)&&L(a.type.ofType)){let c=a.type.ofType,p=r[c.name];if(n.push(a),p===void 0)i(c);else{let l=n.slice(p),d=l.map(h=>h.name).join(".");e.reportError(`Cannot reference Input Object "${c.name}" within itself through a series of non-null fields: "${d}".`,l.map(h=>h.astNode))}n.pop()}r[o.name]=void 0}}function bt(e,t){let{astNode:n,extensionASTNodes:r}=e;return(n!=null?[n,...r]:r).flatMap(o=>{var s;return(s=o.interfaces)!==null&&s!==void 0?s:[]}).filter(o=>o.name.value===t.name)}function Mi(e,t){let{astNode:n,extensionASTNodes:r}=e;return(n!=null?[n,...r]:r).flatMap(o=>{var s;return(s=o.types)!==null&&s!==void 0?s:[]}).filter(o=>o.name.value===t)}function tr(e){var t;return e==null||(t=e.directives)===null||t===void 0?void 0:t.find(n=>n.name.value===Kt.name)}function M(e,t){switch(t.kind){case u.LIST_TYPE:{let n=M(e,t.type);return n&&new A(n)}case u.NON_NULL_TYPE:{let n=M(e,t.type);return n&&new I(n)}case u.NAMED_TYPE:return e.getType(t.name.value)}}var tt=class{constructor(t,n,r){this._schema=t,this._typeStack=[],this._parentTypeStack=[],this._inputTypeStack=[],this._fieldDefStack=[],this._defaultValueStack=[],this._directive=null,this._argument=null,this._enumValue=null,this._getFieldDef=r??as,n&&(H(n)&&this._inputTypeStack.push(n),ae(n)&&this._parentTypeStack.push(n),Ne(n)&&this._typeStack.push(n))}get[Symbol.toStringTag](){return"TypeInfo"}getType(){if(this._typeStack.length>0)return this._typeStack[this._typeStack.length-1]}getParentType(){if(this._parentTypeStack.length>0)return this._parentTypeStack[this._parentTypeStack.length-1]}getInputType(){if(this._inputTypeStack.length>0)return this._inputTypeStack[this._inputTypeStack.length-1]}getParentInputType(){if(this._inputTypeStack.length>1)return this._inputTypeStack[this._inputTypeStack.length-2]}getFieldDef(){if(this._fieldDefStack.length>0)return this._fieldDefStack[this._fieldDefStack.length-1]}getDefaultValue(){if(this._defaultValueStack.length>0)return this._defaultValueStack[this._defaultValueStack.length-1]}getDirective(){return this._directive}getArgument(){return this._argument}getEnumValue(){return this._enumValue}enter(t){let n=this._schema;switch(t.kind){case u.SELECTION_SET:{let i=q(this.getType());this._parentTypeStack.push(ae(i)?i:void 0);break}case u.FIELD:{let i=this.getParentType(),o,s;i&&(o=this._getFieldDef(n,i,t),o&&(s=o.type)),this._fieldDefStack.push(o),this._typeStack.push(Ne(s)?s:void 0);break}case u.DIRECTIVE:this._directive=n.getDirective(t.name.value);break;case u.OPERATION_DEFINITION:{let i=n.getRootType(t.operation);this._typeStack.push(O(i)?i:void 0);break}case u.INLINE_FRAGMENT:case u.FRAGMENT_DEFINITION:{let i=t.typeCondition,o=i?M(n,i):q(this.getType());this._typeStack.push(Ne(o)?o:void 0);break}case u.VARIABLE_DEFINITION:{let i=M(n,t.type);this._inputTypeStack.push(H(i)?i:void 0);break}case u.ARGUMENT:{var r;let i,o,s=(r=this.getDirective())!==null&&r!==void 0?r:this.getFieldDef();s&&(i=s.args.find(a=>a.name===t.name.value),i&&(o=i.type)),this._argument=i,this._defaultValueStack.push(i?i.defaultValue:void 0),this._inputTypeStack.push(H(o)?o:void 0);break}case u.LIST:{let i=Ke(this.getInputType()),o=w(i)?i.ofType:i;this._defaultValueStack.push(void 0),this._inputTypeStack.push(H(o)?o:void 0);break}case u.OBJECT_FIELD:{let i=q(this.getInputType()),o,s;L(i)&&(s=i.getFields()[t.name.value],s&&(o=s.type)),this._defaultValueStack.push(s?s.defaultValue:void 0),this._inputTypeStack.push(H(o)?o:void 0);break}case u.ENUM:{let i=q(this.getInputType()),o;$(i)&&(o=i.getValue(t.value)),this._enumValue=o;break}default:}}leave(t){switch(t.kind){case u.SELECTION_SET:this._parentTypeStack.pop();break;case u.FIELD:this._fieldDefStack.pop(),this._typeStack.pop();break;case u.DIRECTIVE:this._directive=null;break;case u.OPERATION_DEFINITION:case u.INLINE_FRAGMENT:case u.FRAGMENT_DEFINITION:this._typeStack.pop();break;case u.VARIABLE_DEFINITION:this._inputTypeStack.pop();break;case u.ARGUMENT:this._argument=null,this._defaultValueStack.pop(),this._inputTypeStack.pop();break;case u.LIST:case u.OBJECT_FIELD:this._defaultValueStack.pop(),this._inputTypeStack.pop();break;case u.ENUM:this._enumValue=null;break;default:}}};function as(e,t,n){let r=n.name.value;if(r===Ae.name&&e.getQueryType()===t)return Ae;if(r===Fe.name&&e.getQueryType()===t)return Fe;if(r===ke.name&&ae(t))return ke;if(O(t)||_(t))return t.getFields()[r]}function en(e,t){return{enter(...n){let r=n[0];e.enter(r);let i=Je(t,r.kind).enter;if(i){let o=i.apply(t,n);return o!==void 0&&(e.leave(r),ut(o)&&e.enter(o)),o}},leave(...n){let r=n[0],i=Je(t,r.kind).leave,o;return i&&(o=i.apply(t,n)),e.leave(r),o}}}function nr(e){return e.kind===u.OPERATION_DEFINITION||e.kind===u.FRAGMENT_DEFINITION}function rr(e){return e.kind===u.SCHEMA_DEFINITION||Oe(e)||e.kind===u.DIRECTIVE_DEFINITION}function Oe(e){return e.kind===u.SCALAR_TYPE_DEFINITION||e.kind===u.OBJECT_TYPE_DEFINITION||e.kind===u.INTERFACE_TYPE_DEFINITION||e.kind===u.UNION_TYPE_DEFINITION||e.kind===u.ENUM_TYPE_DEFINITION||e.kind===u.INPUT_OBJECT_TYPE_DEFINITION}function ir(e){return e.kind===u.SCHEMA_EXTENSION||tn(e)}function tn(e){return e.kind===u.SCALAR_TYPE_EXTENSION||e.kind===u.OBJECT_TYPE_EXTENSION||e.kind===u.INTERFACE_TYPE_EXTENSION||e.kind===u.UNION_TYPE_EXTENSION||e.kind===u.ENUM_TYPE_EXTENSION||e.kind===u.INPUT_OBJECT_TYPE_EXTENSION}function or(e){return{Document(t){for(let n of t.definitions)if(!nr(n)){let r=n.kind===u.SCHEMA_DEFINITION||n.kind===u.SCHEMA_EXTENSION?"schema":'"'+n.name.value+'"';e.reportError(new f(`The ${r} definition is not executable.`,{nodes:n}))}return!1}}}function sr(e){return{Field(t){let n=e.getParentType();if(n&&!e.getFieldDef()){let i=e.getSchema(),o=t.name.value,s=K("to use an inline fragment on",cs(i,n,o));s===""&&(s=K(us(n,o))),e.reportError(new f(`Cannot query field "${o}" on type "${n.name}".`+s,{nodes:t}))}}}}function cs(e,t,n){if(!ne(t))return[];let r=new Set,i=Object.create(null);for(let s of e.getPossibleTypes(t))if(s.getFields()[n]){r.add(s),i[s.name]=1;for(let a of s.getInterfaces()){var o;a.getFields()[n]&&(r.add(a),i[a.name]=((o=i[a.name])!==null&&o!==void 0?o:0)+1)}}return[...r].sort((s,a)=>{let c=i[a.name]-i[s.name];return c!==0?c:_(s)&&e.isSubType(s,a)?-1:_(a)&&e.isSubType(a,s)?1:Ye(s.name,a.name)}).map(s=>s.name)}function us(e,t){if(O(e)||_(e)){let n=Object.keys(e.getFields());return ee(t,n)}return[]}function ar(e){return{InlineFragment(t){let n=t.typeCondition;if(n){let r=M(e.getSchema(),n);if(r&&!ae(r)){let i=x(n);e.reportError(new f(`Fragment cannot condition on non composite type "${i}".`,{nodes:n}))}}},FragmentDefinition(t){let n=M(e.getSchema(),t.typeCondition);if(n&&!ae(n)){let r=x(t.typeCondition);e.reportError(new f(`Fragment "${t.name.value}" cannot condition on non composite type "${r}".`,{nodes:t.typeCondition}))}}}}function cr(e){return{...ur(e),Argument(t){let n=e.getArgument(),r=e.getFieldDef(),i=e.getParentType();if(!n&&r&&i){let o=t.name.value,s=r.args.map(c=>c.name),a=ee(o,s);e.reportError(new f(`Unknown argument "${o}" on field "${i.name}.${r.name}".`+K(a),{nodes:t}))}}}}function ur(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():Te;for(let s of r)t[s.name]=s.args.map(a=>a.name);let i=e.getDocument().definitions;for(let s of i)if(s.kind===u.DIRECTIVE_DEFINITION){var o;let a=(o=s.arguments)!==null&&o!==void 0?o:[];t[s.name.value]=a.map(c=>c.name.value)}return{Directive(s){let a=s.name.value,c=t[a];if(s.arguments&&c)for(let p of s.arguments){let l=p.name.value;if(!c.includes(l)){let d=ee(l,c);e.reportError(new f(`Unknown argument "${l}" on directive "@${a}".`+K(d),{nodes:p}))}}return!1}}}function nn(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():Te;for(let o of r)t[o.name]=o.locations;let i=e.getDocument().definitions;for(let o of i)o.kind===u.DIRECTIVE_DEFINITION&&(t[o.name.value]=o.locations.map(s=>s.value));return{Directive(o,s,a,c,p){let l=o.name.value,d=t[l];if(!d){e.reportError(new f(`Unknown directive "@${l}".`,{nodes:o}));return}let h=ps(p);h&&!d.includes(h)&&e.reportError(new f(`Directive "@${l}" may not be used on ${h}.`,{nodes:o}))}}}function ps(e){let t=e[e.length-1];switch("kind"in t||C(!1),t.kind){case u.OPERATION_DEFINITION:return ls(t.operation);case u.FIELD:return N.FIELD;case u.FRAGMENT_SPREAD:return N.FRAGMENT_SPREAD;case u.INLINE_FRAGMENT:return N.INLINE_FRAGMENT;case u.FRAGMENT_DEFINITION:return N.FRAGMENT_DEFINITION;case u.VARIABLE_DEFINITION:return N.VARIABLE_DEFINITION;case u.SCHEMA_DEFINITION:case u.SCHEMA_EXTENSION:return N.SCHEMA;case u.SCALAR_TYPE_DEFINITION:case u.SCALAR_TYPE_EXTENSION:return N.SCALAR;case u.OBJECT_TYPE_DEFINITION:case u.OBJECT_TYPE_EXTENSION:return N.OBJECT;case u.FIELD_DEFINITION:return N.FIELD_DEFINITION;case u.INTERFACE_TYPE_DEFINITION:case u.INTERFACE_TYPE_EXTENSION:return N.INTERFACE;case u.UNION_TYPE_DEFINITION:case u.UNION_TYPE_EXTENSION:return N.UNION;case u.ENUM_TYPE_DEFINITION:case u.ENUM_TYPE_EXTENSION:return N.ENUM;case u.ENUM_VALUE_DEFINITION:return N.ENUM_VALUE;case u.INPUT_OBJECT_TYPE_DEFINITION:case u.INPUT_OBJECT_TYPE_EXTENSION:return N.INPUT_OBJECT;case u.INPUT_VALUE_DEFINITION:{let n=e[e.length-3];return"kind"in n||C(!1),n.kind===u.INPUT_OBJECT_TYPE_DEFINITION?N.INPUT_FIELD_DEFINITION:N.ARGUMENT_DEFINITION}default:C(!1,"Unexpected kind: "+y(t.kind))}}function ls(e){switch(e){case F.QUERY:return N.QUERY;case F.MUTATION:return N.MUTATION;case F.SUBSCRIPTION:return N.SUBSCRIPTION}}function pr(e){return{FragmentSpread(t){let n=t.name.value;e.getFragment(n)||e.reportError(new f(`Unknown fragment "${n}".`,{nodes:t.name}))}}}function rn(e){let t=e.getSchema(),n=t?t.getTypeMap():Object.create(null),r=Object.create(null);for(let o of e.getDocument().definitions)Oe(o)&&(r[o.name.value]=!0);let i=[...Object.keys(n),...Object.keys(r)];return{NamedType(o,s,a,c,p){let l=o.name.value;if(!n[l]&&!r[l]){var d;let h=(d=p[2])!==null&&d!==void 0?d:a,T=h!=null&&fs(h);if(T&&Ui.includes(l))return;let g=ee(l,T?Ui.concat(i):i);e.reportError(new f(`Unknown type "${l}".`+K(g),{nodes:o}))}}}}var Ui=[...Jt,...Wt].map(e=>e.name);function fs(e){return"kind"in e&&(rr(e)||ir(e))}function lr(e){let t=0;return{Document(n){t=n.definitions.filter(r=>r.kind===u.OPERATION_DEFINITION).length},OperationDefinition(n){!n.name&&t>1&&e.reportError(new f("This anonymous operation must be the only defined operation.",{nodes:n}))}}}function fr(e){var t,n,r;let i=e.getSchema(),o=(t=(n=(r=i?.astNode)!==null&&r!==void 0?r:i?.getQueryType())!==null&&n!==void 0?n:i?.getMutationType())!==null&&t!==void 0?t:i?.getSubscriptionType(),s=0;return{SchemaDefinition(a){if(o){e.reportError(new f("Cannot define a new schema within a schema extension.",{nodes:a}));return}s>0&&e.reportError(new f("Must provide only one schema definition.",{nodes:a})),++s}}}var ds=3;function dr(e){function t(n,r=Object.create(null),i=0){if(n.kind===u.FRAGMENT_SPREAD){let o=n.name.value;if(r[o]===!0)return!1;let s=e.getFragment(o);if(!s)return!1;try{return r[o]=!0,t(s,r,i)}finally{r[o]=void 0}}if(n.kind===u.FIELD&&(n.name.value==="fields"||n.name.value==="interfaces"||n.name.value==="possibleTypes"||n.name.value==="inputFields")&&(i++,i>=ds))return!0;if("selectionSet"in n&&n.selectionSet){for(let o of n.selectionSet.selections)if(t(o,r,i))return!0}return!1}return{Field(n){if((n.name.value==="__schema"||n.name.value==="__type")&&t(n))return e.reportError(new f("Maximum introspection depth exceeded",{nodes:[n]})),!1}}}function mr(e){let t=Object.create(null),n=[],r=Object.create(null);return{OperationDefinition:()=>!1,FragmentDefinition(o){return i(o),!1}};function i(o){if(t[o.name.value])return;let s=o.name.value;t[s]=!0;let a=e.getFragmentSpreads(o.selectionSet);if(a.length!==0){r[s]=n.length;for(let c of a){let p=c.name.value,l=r[p];if(n.push(c),l===void 0){let d=e.getFragment(p);d&&i(d)}else{let d=n.slice(l),h=d.slice(0,-1).map(T=>'"'+T.name.value+'"').join(", ");e.reportError(new f(`Cannot spread fragment "${p}" within itself`+(h!==""?` via ${h}.`:"."),{nodes:d}))}n.pop()}r[s]=void 0}}}function hr(e){let t=Object.create(null);return{OperationDefinition:{enter(){t=Object.create(null)},leave(n){let r=e.getRecursiveVariableUsages(n);for(let{node:i}of r){let o=i.name.value;t[o]!==!0&&e.reportError(new f(n.name?`Variable "$${o}" is not defined by operation "${n.name.value}".`:`Variable "$${o}" is not defined.`,{nodes:[i,n]}))}}},VariableDefinition(n){t[n.variable.name.value]=!0}}}function yr(e){let t=[],n=[];return{OperationDefinition(r){return t.push(r),!1},FragmentDefinition(r){return n.push(r),!1},Document:{leave(){let r=Object.create(null);for(let i of t)for(let o of e.getRecursivelyReferencedFragments(i))r[o.name.value]=!0;for(let i of n){let o=i.name.value;r[o]!==!0&&e.reportError(new f(`Fragment "${o}" is never used.`,{nodes:i}))}}}}}function Tr(e){let t=[];return{OperationDefinition:{enter(){t=[]},leave(n){let r=Object.create(null),i=e.getRecursiveVariableUsages(n);for(let{node:o}of i)r[o.name.value]=!0;for(let o of t){let s=o.variable.name.value;r[s]!==!0&&e.reportError(new f(n.name?`Variable "$${s}" is never used in operation "${n.name.value}".`:`Variable "$${s}" is never used.`,{nodes:o}))}}},VariableDefinition(n){t.push(n)}}}function on(e){switch(e.kind){case u.OBJECT:return{...e,fields:ms(e.fields)};case u.LIST:return{...e,values:e.values.map(on)};case u.INT:case u.FLOAT:case u.STRING:case u.BOOLEAN:case u.NULL:case u.ENUM:case u.VARIABLE:return e}}function ms(e){return e.map(t=>({...t,value:on(t.value)})).sort((t,n)=>Ye(t.name.value,n.name.value))}function Vi(e){return Array.isArray(e)?e.map(([t,n])=>`subfields "${t}" conflict because `+Vi(n)).join(" and "):e}function Nr(e){let t=new un,n=new vr,r=new Map;return{SelectionSet(i){let o=hs(e,r,t,n,e.getParentType(),i);for(let[[s,a],c,p]of o){let l=Vi(a);e.reportError(new f(`Fields "${s}" conflict because ${l}. Use different aliases on the fields to fetch both if this was intentional.`,{nodes:c.concat(p)}))}}}}function hs(e,t,n,r,i,o){let s=[],[a,c]=cn(e,t,i,o);if(Ts(e,s,t,n,r,a),c.length!==0)for(let p=0;p<c.length;p++){sn(e,s,t,n,r,!1,a,c[p]);for(let l=p+1;l<c.length;l++)an(e,s,t,n,r,!1,c[p],c[l])}return s}function sn(e,t,n,r,i,o,s,a){if(r.has(s,a,o))return;r.add(s,a,o);let c=e.getFragment(a);if(!c)return;let[p,l]=Er(e,n,c);if(s!==p){Ir(e,t,n,r,i,o,s,p);for(let d of l)sn(e,t,n,r,i,o,s,d)}}function an(e,t,n,r,i,o,s,a){if(s===a||i.has(s,a,o))return;i.add(s,a,o);let c=e.getFragment(s),p=e.getFragment(a);if(!c||!p)return;let[l,d]=Er(e,n,c),[h,T]=Er(e,n,p);Ir(e,t,n,r,i,o,l,h);for(let g of T)an(e,t,n,r,i,o,s,g);for(let g of d)an(e,t,n,r,i,o,g,a)}function ys(e,t,n,r,i,o,s,a,c){let p=[],[l,d]=cn(e,t,o,s),[h,T]=cn(e,t,a,c);Ir(e,p,t,n,r,i,l,h);for(let g of T)sn(e,p,t,n,r,i,l,g);for(let g of d)sn(e,p,t,n,r,i,h,g);for(let g of d)for(let D of T)an(e,p,t,n,r,i,g,D);return p}function Ts(e,t,n,r,i,o){for(let[s,a]of Object.entries(o))if(a.length>1)for(let c=0;c<a.length;c++)for(let p=c+1;p<a.length;p++){let l=Gi(e,n,r,i,!1,s,a[c],a[p]);l&&t.push(l)}}function Ir(e,t,n,r,i,o,s,a){for(let[c,p]of Object.entries(s)){let l=a[c];if(l)for(let d of p)for(let h of l){let T=Gi(e,n,r,i,o,c,d,h);T&&t.push(T)}}}function Gi(e,t,n,r,i,o,s,a){let[c,p,l]=s,[d,h,T]=a,g=i||c!==d&&O(c)&&O(d);if(!g){let oe=p.name.value,le=h.name.value;if(oe!==le)return[[o,`"${oe}" and "${le}" are different fields`],[p],[h]];if(!gs(p,h))return[[o,"they have differing arguments"],[p],[h]]}let D=l?.type,k=T?.type;if(D&&k&&gr(D,k))return[[o,`they return conflicting types "${y(D)}" and "${y(k)}"`],[p],[h]];let re=p.selectionSet,st=h.selectionSet;if(re&&st){let oe=ys(e,t,n,r,g,q(D),re,q(k),st);return Es(oe,o,p,h)}}function gs(e,t){let n=e.arguments,r=t.arguments;if(n===void 0||n.length===0)return r===void 0||r.length===0;if(r===void 0||r.length===0||n.length!==r.length)return!1;let i=new Map(r.map(({name:o,value:s})=>[o.value,s]));return n.every(o=>{let s=o.value,a=i.get(o.name.value);return a===void 0?!1:$i(s)===$i(a)})}function $i(e){return x(on(e))}function gr(e,t){return w(e)?w(t)?gr(e.ofType,t.ofType):!0:w(t)?!0:b(e)?b(t)?gr(e.ofType,t.ofType):!0:b(t)?!0:J(e)||J(t)?e!==t:!1}function cn(e,t,n,r){let i=t.get(r);if(i)return i;let o=Object.create(null),s=Object.create(null);ji(e,n,r,o,s);let a=[o,Object.keys(s)];return t.set(r,a),a}function Er(e,t,n){let r=t.get(n.selectionSet);if(r)return r;let i=M(e.getSchema(),n.typeCondition);return cn(e,t,i,n.selectionSet)}function ji(e,t,n,r,i){for(let o of n.selections)switch(o.kind){case u.FIELD:{let s=o.name.value,a;(O(t)||_(t))&&(a=t.getFields()[s]);let c=o.alias?o.alias.value:s;r[c]||(r[c]=[]),r[c].push([t,o,a]);break}case u.FRAGMENT_SPREAD:i[o.name.value]=!0;break;case u.INLINE_FRAGMENT:{let s=o.typeCondition,a=s?M(e.getSchema(),s):t;ji(e,a,o.selectionSet,r,i);break}}}function Es(e,t,n,r){if(e.length>0)return[[t,e.map(([i])=>i)],[n,...e.map(([,i])=>i).flat()],[r,...e.map(([,,i])=>i).flat()]]}var un=class{constructor(){this._data=new Map}has(t,n,r){var i;let o=(i=this._data.get(t))===null||i===void 0?void 0:i.get(n);return o===void 0?!1:r?!0:r===o}add(t,n,r){let i=this._data.get(t);i===void 0?this._data.set(t,new Map([[n,r]])):i.set(n,r)}},vr=class{constructor(){this._orderedPairSet=new un}has(t,n,r){return t<n?this._orderedPairSet.has(t,n,r):this._orderedPairSet.has(n,t,r)}add(t,n,r){t<n?this._orderedPairSet.add(t,n,r):this._orderedPairSet.add(n,t,r)}};function br(e){return{InlineFragment(t){let n=e.getType(),r=e.getParentType();if(ae(n)&&ae(r)&&!qn(e.getSchema(),n,r)){let i=y(r),o=y(n);e.reportError(new f(`Fragment cannot be spread here as objects of type "${i}" can never be of type "${o}".`,{nodes:t}))}},FragmentSpread(t){let n=t.name.value,r=vs(e,n),i=e.getParentType();if(r&&i&&!qn(e.getSchema(),r,i)){let o=y(i),s=y(r);e.reportError(new f(`Fragment "${n}" cannot be spread here as objects of type "${o}" can never be of type "${s}".`,{nodes:t}))}}}}function vs(e,t){let n=e.getFragment(t);if(n){let r=M(e.getSchema(),n.typeCondition);if(ae(r))return r}}function Rr(e){let t=e.getSchema(),n=Object.create(null);for(let i of e.getDocument().definitions)Oe(i)&&(n[i.name.value]=i);return{ScalarTypeExtension:r,ObjectTypeExtension:r,InterfaceTypeExtension:r,UnionTypeExtension:r,EnumTypeExtension:r,InputObjectTypeExtension:r};function r(i){let o=i.name.value,s=n[o],a=t?.getType(o),c;if(s?c=Ns[s.kind]:a&&(c=Is(a)),c){if(c!==i.kind){let p=bs(i.kind);e.reportError(new f(`Cannot extend non-${p} type "${o}".`,{nodes:s?[s,i]:i}))}}else{let p=Object.keys({...n,...t?.getTypeMap()}),l=ee(o,p);e.reportError(new f(`Cannot extend type "${o}" because it is not defined.`+K(l),{nodes:i.name}))}}}var Ns={[u.SCALAR_TYPE_DEFINITION]:u.SCALAR_TYPE_EXTENSION,[u.OBJECT_TYPE_DEFINITION]:u.OBJECT_TYPE_EXTENSION,[u.INTERFACE_TYPE_DEFINITION]:u.INTERFACE_TYPE_EXTENSION,[u.UNION_TYPE_DEFINITION]:u.UNION_TYPE_EXTENSION,[u.ENUM_TYPE_DEFINITION]:u.ENUM_TYPE_EXTENSION,[u.INPUT_OBJECT_TYPE_DEFINITION]:u.INPUT_OBJECT_TYPE_EXTENSION};function Is(e){if(he(e))return u.SCALAR_TYPE_EXTENSION;if(O(e))return u.OBJECT_TYPE_EXTENSION;if(_(e))return u.INTERFACE_TYPE_EXTENSION;if(Y(e))return u.UNION_TYPE_EXTENSION;if($(e))return u.ENUM_TYPE_EXTENSION;if(L(e))return u.INPUT_OBJECT_TYPE_EXTENSION;C(!1,"Unexpected type: "+y(e))}function bs(e){switch(e){case u.SCALAR_TYPE_EXTENSION:return"scalar";case u.OBJECT_TYPE_EXTENSION:return"object";case u.INTERFACE_TYPE_EXTENSION:return"interface";case u.UNION_TYPE_EXTENSION:return"union";case u.ENUM_TYPE_EXTENSION:return"enum";case u.INPUT_OBJECT_TYPE_EXTENSION:return"input object";default:C(!1,"Unexpected kind: "+y(e))}}function Or(e){return{...Sr(e),Field:{leave(t){var n;let r=e.getFieldDef();if(!r)return!1;let i=new Set((n=t.arguments)===null||n===void 0?void 0:n.map(o=>o.name.value));for(let o of r.args)if(!i.has(o.name)&&Ie(o)){let s=y(o.type);e.reportError(new f(`Field "${r.name}" argument "${o.name}" of type "${s}" is required, but it was not provided.`,{nodes:t}))}}}}}function Sr(e){var t;let n=Object.create(null),r=e.getSchema(),i=(t=r?.getDirectives())!==null&&t!==void 0?t:Te;for(let a of i)n[a.name]=fe(a.args.filter(Ie),c=>c.name);let o=e.getDocument().definitions;for(let a of o)if(a.kind===u.DIRECTIVE_DEFINITION){var s;let c=(s=a.arguments)!==null&&s!==void 0?s:[];n[a.name.value]=fe(c.filter(Rs),p=>p.name.value)}return{Directive:{leave(a){let c=a.name.value,p=n[c];if(p){var l;let d=(l=a.arguments)!==null&&l!==void 0?l:[],h=new Set(d.map(T=>T.name.value));for(let[T,g]of Object.entries(p))if(!h.has(T)){let D=Xe(g.type)?y(g.type):x(g.type);e.reportError(new f(`Directive "@${c}" argument "${T}" of type "${D}" is required, but it was not provided.`,{nodes:a}))}}}}}}function Rs(e){return e.type.kind===u.NON_NULL_TYPE&&e.defaultValue==null}function _r(e){return{Field(t){let n=e.getType(),r=t.selectionSet;if(n)if(J(q(n))){if(r){let i=t.name.value,o=y(n);e.reportError(new f(`Field "${i}" must not have a selection since type "${o}" has no subfields.`,{nodes:r}))}}else if(r){if(r.selections.length===0){let i=t.name.value,o=y(n);e.reportError(new f(`Field "${i}" of type "${o}" must have at least one field selected.`,{nodes:t}))}}else{let i=t.name.value,o=y(n);e.reportError(new f(`Field "${i}" of type "${o}" must have a selection of subfields. Did you mean "${i} { ... }"?`,{nodes:t}))}}}}function pn(e){return e.map(t=>typeof t=="number"?"["+t.toString()+"]":"."+t).join("")}function Pe(e,t,n){return{prev:e,key:t,typename:n}}function W(e){let t=[],n=e;for(;n;)t.push(n.key),n=n.prev;return t.reverse()}function Qi(e,t,n=Os){return Ot(e,t,n,void 0)}function Os(e,t,n){let r="Invalid value "+y(t);throw e.length>0&&(r+=` at "value${pn(e)}"`),n.message=r+": "+n.message,n}function Ot(e,t,n,r){if(b(t)){if(e!=null)return Ot(e,t.ofType,n,r);n(W(r),e,new f(`Expected non-nullable type "${y(t)}" not to be null.`));return}if(e==null)return null;if(w(t)){let i=t.ofType;return Ze(e)?Array.from(e,(o,s)=>{let a=Pe(r,s,void 0);return Ot(o,i,n,a)}):[Ot(e,i,n,r)]}if(L(t)){if(!j(e)){n(W(r),e,new f(`Expected type "${t.name}" to be an object.`));return}let i={},o=t.getFields();for(let s of Object.values(o)){let a=e[s.name];if(a===void 0){if(s.defaultValue!==void 0)i[s.name]=s.defaultValue;else if(b(s.type)){let c=y(s.type);n(W(r),e,new f(`Field "${s.name}" of required type "${c}" was not provided.`))}continue}i[s.name]=Ot(a,s.type,n,Pe(r,s.name,t.name))}for(let s of Object.keys(e))if(!o[s]){let a=ee(s,Object.keys(t.getFields()));n(W(r),e,new f(`Field "${s}" is not defined by type "${t.name}".`+K(a)))}if(t.isOneOf){let s=Object.keys(i);s.length!==1&&n(W(r),e,new f(`Exactly one key must be specified for OneOf type "${t.name}".`));let a=s[0],c=i[a];c===null&&n(W(r).concat(a),c,new f(`Field "${a}" must be non-null.`))}return i}if(J(t)){let i;try{i=t.parseValue(e)}catch(o){o instanceof f?n(W(r),e,o):n(W(r),e,new f(`Expected type "${t.name}". `+o.message,{originalError:o}));return}return i===void 0&&n(W(r),e,new f(`Expected type "${t.name}".`)),i}C(!1,"Unexpected input type: "+y(t))}function Ue(e,t,n){if(e){if(e.kind===u.VARIABLE){let r=e.name.value;if(n==null||n[r]===void 0)return;let i=n[r];return i===null&&b(t)?void 0:i}if(b(t))return e.kind===u.NULL?void 0:Ue(e,t.ofType,n);if(e.kind===u.NULL)return null;if(w(t)){let r=t.ofType;if(e.kind===u.LIST){let o=[];for(let s of e.values)if(Bi(s,n)){if(b(r))return;o.push(null)}else{let a=Ue(s,r,n);if(a===void 0)return;o.push(a)}return o}let i=Ue(e,r,n);return i===void 0?void 0:[i]}if(L(t)){if(e.kind!==u.OBJECT)return;let r=Object.create(null),i=fe(e.fields,o=>o.name.value);for(let o of Object.values(t.getFields())){let s=i[o.name];if(!s||Bi(s.value,n)){if(o.defaultValue!==void 0)r[o.name]=o.defaultValue;else if(b(o.type))return;continue}let a=Ue(s.value,o.type,n);if(a===void 0)return;r[o.name]=a}if(t.isOneOf){let o=Object.keys(r);if(o.length!==1||r[o[0]]===null)return}return r}if(J(t)){let r;try{r=t.parseLiteral(e,n)}catch{return}return r===void 0?void 0:r}C(!1,"Unexpected input type: "+y(t))}}function Bi(e,t){return e.kind===u.VARIABLE&&(t==null||t[e.name.value]===void 0)}function xr(e,t,n,r){let i=[],o=r?.maxErrors;try{let s=Ss(e,t,n,a=>{if(o!=null&&i.length>=o)throw new f("Too many errors processing variables, error limit reached. Execution aborted.");i.push(a)});if(i.length===0)return{coerced:s}}catch(s){i.push(s)}return{errors:i}}function Ss(e,t,n,r){let i={};for(let o of t){let s=o.variable.name.value,a=M(e,o.type);if(!H(a)){let p=x(o.type);r(new f(`Variable "$${s}" expected value of type "${p}" which cannot be used as an input type.`,{nodes:o.type}));continue}if(!qi(n,s)){if(o.defaultValue)i[s]=Ue(o.defaultValue,a);else if(b(a)){let p=y(a);r(new f(`Variable "$${s}" of required type "${p}" was not provided.`,{nodes:o}))}continue}let c=n[s];if(c===null&&b(a)){let p=y(a);r(new f(`Variable "$${s}" of non-null type "${p}" must not be null.`,{nodes:o}));continue}i[s]=Qi(c,a,(p,l,d)=>{let h=`Variable "$${s}" got invalid value `+y(l);p.length>0&&(h+=` at "${s}${pn(p)}"`),r(new f(h+"; "+d.message,{nodes:o,originalError:d}))})}return i}function ln(e,t,n){var r;let i={},o=(r=t.arguments)!==null&&r!==void 0?r:[],s=fe(o,a=>a.name.value);for(let a of e.args){let c=a.name,p=a.type,l=s[c];if(!l){if(a.defaultValue!==void 0)i[c]=a.defaultValue;else if(b(p))throw new f(`Argument "${c}" of required type "${y(p)}" was not provided.`,{nodes:t});continue}let d=l.value,h=d.kind===u.NULL;if(d.kind===u.VARIABLE){let g=d.name.value;if(n==null||!qi(n,g)){if(a.defaultValue!==void 0)i[c]=a.defaultValue;else if(b(p))throw new f(`Argument "${c}" of required type "${y(p)}" was provided the variable "$${g}" which was not provided a runtime value.`,{nodes:d});continue}h=n[g]==null}if(h&&b(p))throw new f(`Argument "${c}" of non-null type "${y(p)}" must not be null.`,{nodes:d});let T=Ue(d,p,n);if(T===void 0)throw new f(`Argument "${c}" has invalid value ${x(d)}.`,{nodes:d});i[c]=T}return i}function fn(e,t,n){var r;let i=(r=t.directives)===null||r===void 0?void 0:r.find(o=>o.name.value===e.name);if(i)return ln(e,i,n)}function qi(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function mn(e,t,n,r,i){let o=new Map;return dn(e,t,n,r,i,o,new Set),o}function Hi(e,t,n,r,i){let o=new Map,s=new Set;for(let a of i)a.selectionSet&&dn(e,t,n,r,a.selectionSet,o,s);return o}function dn(e,t,n,r,i,o,s){for(let a of i.selections)switch(a.kind){case u.FIELD:{if(!Lr(n,a))continue;let c=_s(a),p=o.get(c);p!==void 0?p.push(a):o.set(c,[a]);break}case u.INLINE_FRAGMENT:{if(!Lr(n,a)||!Yi(e,a,r))continue;dn(e,t,n,r,a.selectionSet,o,s);break}case u.FRAGMENT_SPREAD:{let c=a.name.value;if(s.has(c)||!Lr(n,a))continue;s.add(c);let p=t[c];if(!p||!Yi(e,p,r))continue;dn(e,t,n,r,p.selectionSet,o,s);break}}}function Lr(e,t){let n=fn(Xt,t,e);if(n?.if===!0)return!1;let r=fn(zt,t,e);return r?.if!==!1}function Yi(e,t,n){let r=t.typeCondition;if(!r)return!0;let i=M(e,r);return i===n?!0:ne(i)?e.isSubType(i,n):!1}function _s(e){return e.alias?e.alias.value:e.name.value}function wr(e){return{OperationDefinition(t){if(t.operation==="subscription"){let n=e.getSchema(),r=n.getSubscriptionType();if(r){let i=t.name?t.name.value:null,o=Object.create(null),s=e.getDocument(),a=Object.create(null);for(let p of s.definitions)p.kind===u.FRAGMENT_DEFINITION&&(a[p.name.value]=p);let c=mn(n,a,o,r,t.selectionSet);if(c.size>1){let d=[...c.values()].slice(1).flat();e.reportError(new f(i!=null?`Subscription "${i}" must select only one top level field.`:"Anonymous Subscription must select only one top level field.",{nodes:d}))}for(let p of c.values())p[0].name.value.startsWith("__")&&e.reportError(new f(i!=null?`Subscription "${i}" must not select an introspection top level field.`:"Anonymous Subscription must not select an introspection top level field.",{nodes:p}))}}}}}function nt(e,t){let n=new Map;for(let r of e){let i=t(r),o=n.get(i);o===void 0?n.set(i,[r]):o.push(r)}return n}function Dr(e){return{DirectiveDefinition(r){var i;let o=(i=r.arguments)!==null&&i!==void 0?i:[];return n(`@${r.name.value}`,o)},InterfaceTypeDefinition:t,InterfaceTypeExtension:t,ObjectTypeDefinition:t,ObjectTypeExtension:t};function t(r){var i;let o=r.name.value,s=(i=r.fields)!==null&&i!==void 0?i:[];for(let c of s){var a;let p=c.name.value,l=(a=c.arguments)!==null&&a!==void 0?a:[];n(`${o}.${p}`,l)}return!1}function n(r,i){let o=nt(i,s=>s.name.value);for(let[s,a]of o)a.length>1&&e.reportError(new f(`Argument "${r}(${s}:)" can only be defined once.`,{nodes:a.map(c=>c.name)}));return!1}}function hn(e){return{Field:t,Directive:t};function t(n){var r;let i=(r=n.arguments)!==null&&r!==void 0?r:[],o=nt(i,s=>s.name.value);for(let[s,a]of o)a.length>1&&e.reportError(new f(`There can be only one argument named "${s}".`,{nodes:a.map(c=>c.name)}))}}function Ar(e){let t=Object.create(null),n=e.getSchema();return{DirectiveDefinition(r){let i=r.name.value;if(n!=null&&n.getDirective(i)){e.reportError(new f(`Directive "@${i}" already exists in the schema. It cannot be redefined.`,{nodes:r.name}));return}return t[i]?e.reportError(new f(`There can be only one directive named "@${i}".`,{nodes:[t[i],r.name]})):t[i]=r.name,!1}}}function yn(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():Te;for(let a of r)t[a.name]=!a.isRepeatable;let i=e.getDocument().definitions;for(let a of i)a.kind===u.DIRECTIVE_DEFINITION&&(t[a.name.value]=!a.repeatable);let o=Object.create(null),s=Object.create(null);return{enter(a){if(!("directives"in a)||!a.directives)return;let c;if(a.kind===u.SCHEMA_DEFINITION||a.kind===u.SCHEMA_EXTENSION)c=o;else if(Oe(a)||tn(a)){let p=a.name.value;c=s[p],c===void 0&&(s[p]=c=Object.create(null))}else c=Object.create(null);for(let p of a.directives){let l=p.name.value;t[l]&&(c[l]?e.reportError(new f(`The directive "@${l}" can only be used once at this location.`,{nodes:[c[l],p]})):c[l]=p)}}}}function Fr(e){let t=e.getSchema(),n=t?t.getTypeMap():Object.create(null),r=Object.create(null);return{EnumTypeDefinition:i,EnumTypeExtension:i};function i(o){var s;let a=o.name.value;r[a]||(r[a]=Object.create(null));let c=(s=o.values)!==null&&s!==void 0?s:[],p=r[a];for(let l of c){let d=l.name.value,h=n[a];$(h)&&h.getValue(d)?e.reportError(new f(`Enum value "${a}.${d}" already exists in the schema. It cannot also be defined in this type extension.`,{nodes:l.name})):p[d]?e.reportError(new f(`Enum value "${a}.${d}" can only be defined once.`,{nodes:[p[d],l.name]})):p[d]=l.name}return!1}}function kr(e){let t=e.getSchema(),n=t?t.getTypeMap():Object.create(null),r=Object.create(null);return{InputObjectTypeDefinition:i,InputObjectTypeExtension:i,InterfaceTypeDefinition:i,InterfaceTypeExtension:i,ObjectTypeDefinition:i,ObjectTypeExtension:i};function i(o){var s;let a=o.name.value;r[a]||(r[a]=Object.create(null));let c=(s=o.fields)!==null&&s!==void 0?s:[],p=r[a];for(let l of c){let d=l.name.value;xs(n[a],d)?e.reportError(new f(`Field "${a}.${d}" already exists in the schema. It cannot also be defined in this type extension.`,{nodes:l.name})):p[d]?e.reportError(new f(`Field "${a}.${d}" can only be defined once.`,{nodes:[p[d],l.name]})):p[d]=l.name}return!1}}function xs(e,t){return O(e)||_(e)||L(e)?e.getFields()[t]!=null:!1}function Cr(e){let t=Object.create(null);return{OperationDefinition:()=>!1,FragmentDefinition(n){let r=n.name.value;return t[r]?e.reportError(new f(`There can be only one fragment named "${r}".`,{nodes:[t[r],n.name]})):t[r]=n.name,!1}}}function Tn(e){let t=[],n=Object.create(null);return{ObjectValue:{enter(){t.push(n),n=Object.create(null)},leave(){let r=t.pop();r||C(!1),n=r}},ObjectField(r){let i=r.name.value;n[i]?e.reportError(new f(`There can be only one input field named "${i}".`,{nodes:[n[i],r.name]})):n[i]=r.name}}}function Mr(e){let t=Object.create(null);return{OperationDefinition(n){let r=n.name;return r&&(t[r.value]?e.reportError(new f(`There can be only one operation named "${r.value}".`,{nodes:[t[r.value],r]})):t[r.value]=r),!1},FragmentDefinition:()=>!1}}function Pr(e){let t=e.getSchema(),n=Object.create(null),r=t?{query:t.getQueryType(),mutation:t.getMutationType(),subscription:t.getSubscriptionType()}:{};return{SchemaDefinition:i,SchemaExtension:i};function i(o){var s;let a=(s=o.operationTypes)!==null&&s!==void 0?s:[];for(let c of a){let p=c.operation,l=n[p];r[p]?e.reportError(new f(`Type for ${p} already defined in the schema. It cannot be redefined.`,{nodes:c})):l?e.reportError(new f(`There can be only one ${p} type in schema.`,{nodes:[l,c]})):n[p]=c}return!1}}function Ur(e){let t=Object.create(null),n=e.getSchema();return{ScalarTypeDefinition:r,ObjectTypeDefinition:r,InterfaceTypeDefinition:r,UnionTypeDefinition:r,EnumTypeDefinition:r,InputObjectTypeDefinition:r};function r(i){let o=i.name.value;if(n!=null&&n.getType(o)){e.reportError(new f(`Type "${o}" already exists in the schema. It cannot also be defined in this type definition.`,{nodes:i.name}));return}return t[o]?e.reportError(new f(`There can be only one type named "${o}".`,{nodes:[t[o],i.name]})):t[o]=i.name,!1}}function $r(e){return{OperationDefinition(t){var n;let r=(n=t.variableDefinitions)!==null&&n!==void 0?n:[],i=nt(r,o=>o.variable.name.value);for(let[o,s]of i)s.length>1&&e.reportError(new f(`There can be only one variable named "$${o}".`,{nodes:s.map(a=>a.variable.name)}))}}}function Vr(e){let t={};return{OperationDefinition:{enter(){t={}}},VariableDefinition(n){t[n.variable.name.value]=n},ListValue(n){let r=Ke(e.getParentInputType());if(!w(r))return $e(e,n),!1},ObjectValue(n){let r=q(e.getInputType());if(!L(r))return $e(e,n),!1;let i=fe(n.fields,o=>o.name.value);for(let o of Object.values(r.getFields()))if(!i[o.name]&&We(o)){let a=y(o.type);e.reportError(new f(`Field "${r.name}.${o.name}" of required type "${a}" was not provided.`,{nodes:n}))}r.isOneOf&&Ls(e,n,r,i,t)},ObjectField(n){let r=q(e.getParentInputType());if(!e.getInputType()&&L(r)){let o=ee(n.name.value,Object.keys(r.getFields()));e.reportError(new f(`Field "${n.name.value}" is not defined by type "${r.name}".`+K(o),{nodes:n}))}},NullValue(n){let r=e.getInputType();b(r)&&e.reportError(new f(`Expected value of type "${y(r)}", found ${x(n)}.`,{nodes:n}))},EnumValue:n=>$e(e,n),IntValue:n=>$e(e,n),FloatValue:n=>$e(e,n),StringValue:n=>$e(e,n),BooleanValue:n=>$e(e,n)}}function $e(e,t){let n=e.getInputType();if(!n)return;let r=q(n);if(!J(r)){let i=y(n);e.reportError(new f(`Expected value of type "${i}", found ${x(t)}.`,{nodes:t}));return}try{if(r.parseLiteral(t,void 0)===void 0){let o=y(n);e.reportError(new f(`Expected value of type "${o}", found ${x(t)}.`,{nodes:t}))}}catch(i){let o=y(n);i instanceof f?e.reportError(i):e.reportError(new f(`Expected value of type "${o}", found ${x(t)}; `+i.message,{nodes:t,originalError:i}))}}function Ls(e,t,n,r,i){var o;let s=Object.keys(r);if(s.length!==1){e.reportError(new f(`OneOf Input Object "${n.name}" must specify exactly one key.`,{nodes:[t]}));return}let c=(o=r[s[0]])===null||o===void 0?void 0:o.value,p=!c||c.kind===u.NULL,l=c?.kind===u.VARIABLE;if(p){e.reportError(new f(`Field "${n.name}.${s[0]}" must be non-null.`,{nodes:[t]}));return}if(l){let d=c.name.value;i[d].type.kind!==u.NON_NULL_TYPE&&e.reportError(new f(`Variable "${d}" must be non-nullable to be used for OneOf Input Object "${n.name}".`,{nodes:[t]}))}}function Gr(e){return{VariableDefinition(t){let n=M(e.getSchema(),t.type);if(n!==void 0&&!H(n)){let r=t.variable.name.value,i=x(t.type);e.reportError(new f(`Variable "$${r}" cannot be non-input type "${i}".`,{nodes:t.type}))}}}}function jr(e){let t=Object.create(null);return{OperationDefinition:{enter(){t=Object.create(null)},leave(n){let r=e.getRecursiveVariableUsages(n);for(let{node:i,type:o,defaultValue:s}of r){let a=i.name.value,c=t[a];if(c&&o){let p=e.getSchema(),l=M(p,c.type);if(l&&!ws(p,l,c.defaultValue,o,s)){let d=y(l),h=y(o);e.reportError(new f(`Variable "$${a}" of type "${d}" used in position expecting type "${h}".`,{nodes:[c,i]}))}}}}},VariableDefinition(n){t[n.variable.name.value]=n}}}function ws(e,t,n,r,i){if(b(r)&&!b(t)){if(!(n!=null&&n.kind!==u.NULL)&&!(i!==void 0))return!1;let a=r.ofType;return Re(e,t,a)}return Re(e,t,r)}var Qr=Object.freeze([dr]),rt=Object.freeze([or,Mr,lr,wr,rn,ar,Gr,_r,sr,Cr,pr,yr,br,mr,$r,hr,Tr,nn,yn,cr,hn,Vr,Or,jr,Nr,Tn,...Qr]),Ds=Object.freeze([fr,Pr,Ur,Fr,kr,Dr,Ar,rn,nn,yn,Rr,ur,hn,Tn,Sr]);var Br=class{constructor(t,n){this._ast=t,this._fragments=void 0,this._fragmentSpreads=new Map,this._recursivelyReferencedFragments=new Map,this._onError=n}get[Symbol.toStringTag](){return"ASTValidationContext"}reportError(t){this._onError(t)}getDocument(){return this._ast}getFragment(t){let n;if(this._fragments)n=this._fragments;else{n=Object.create(null);for(let r of this.getDocument().definitions)r.kind===u.FRAGMENT_DEFINITION&&(n[r.name.value]=r);this._fragments=n}return n[t]}getFragmentSpreads(t){let n=this._fragmentSpreads.get(t);if(!n){n=[];let r=[t],i;for(;i=r.pop();)for(let o of i.selections)o.kind===u.FRAGMENT_SPREAD?n.push(o):o.selectionSet&&r.push(o.selectionSet);this._fragmentSpreads.set(t,n)}return n}getRecursivelyReferencedFragments(t){let n=this._recursivelyReferencedFragments.get(t);if(!n){n=[];let r=Object.create(null),i=[t.selectionSet],o;for(;o=i.pop();)for(let s of this.getFragmentSpreads(o)){let a=s.name.value;if(r[a]!==!0){r[a]=!0;let c=this.getFragment(a);c&&(n.push(c),i.push(c.selectionSet))}}this._recursivelyReferencedFragments.set(t,n)}return n}};var St=class extends Br{constructor(t,n,r,i){super(n,i),this._schema=t,this._typeInfo=r,this._variableUsages=new Map,this._recursiveVariableUsages=new Map}get[Symbol.toStringTag](){return"ValidationContext"}getSchema(){return this._schema}getVariableUsages(t){let n=this._variableUsages.get(t);if(!n){let r=[],i=new tt(this._schema);Le(t,en(i,{VariableDefinition:()=>!1,Variable(o){r.push({node:o,type:i.getInputType(),defaultValue:i.getDefaultValue()})}})),n=r,this._variableUsages.set(t,n)}return n}getRecursiveVariableUsages(t){let n=this._recursiveVariableUsages.get(t);if(!n){n=this.getVariableUsages(t);for(let r of this.getRecursivelyReferencedFragments(t))n=n.concat(this.getVariableUsages(r));this._recursiveVariableUsages.set(t,n)}return n}getType(){return this._typeInfo.getType()}getParentType(){return this._typeInfo.getParentType()}getInputType(){return this._typeInfo.getInputType()}getParentInputType(){return this._typeInfo.getParentInputType()}getFieldDef(){return this._typeInfo.getFieldDef()}getDirective(){return this._typeInfo.getDirective()}getArgument(){return this._typeInfo.getArgument()}getEnumValue(){return this._typeInfo.getEnumValue()}};function gn(e,t,n=rt,r,i=new tt(e)){var o;let s=(o=r?.maxErrors)!==null&&o!==void 0?o:100;t||R(!1,"Must provide document."),Rt(e);let a=Object.freeze({}),c=[],p=new St(e,t,i,d=>{if(c.length>=s)throw c.push(new f("Too many validation errors, error limit reached. Validation aborted.")),a;c.push(d)}),l=Vn(n.map(d=>d(p)));try{Le(t,en(i,l))}catch(d){if(d!==a)throw d}return c}function Ji(e){let t;return function(r,i,o){t===void 0&&(t=new WeakMap);let s=t.get(r);s===void 0&&(s=new WeakMap,t.set(r,s));let a=s.get(i);a===void 0&&(a=new WeakMap,s.set(i,a));let c=a.get(o);return c===void 0&&(c=e(r,i,o),a.set(o,c)),c}}function qr(e){return Promise.all(Object.values(e)).then(t=>{let n=Object.create(null);for(let[r,i]of Object.keys(e).entries())n[i]=t[r];return n})}function zi(e,t,n){let r=n;for(let i of e)r=se(r)?r.then(o=>t(o,i)):t(r,i);return r}function Xi(e){return e instanceof Error?e:new Yr(e)}var Yr=class extends Error{constructor(t){super("Unexpected error value: "+y(t)),this.name="NonErrorThrown",this.thrownValue=t}};function _t(e,t,n){var r;let i=Xi(e);return As(i)?i:new f(i.message,{nodes:(r=i.nodes)!==null&&r!==void 0?r:t,source:i.source,positions:i.positions,path:n,originalError:i})}function As(e){return Array.isArray(e.path)}var Fs=Ji((e,t,n)=>Hi(e.schema,e.fragments,e.variableValues,t,n));function bn(e){arguments.length<2||R(!1,"graphql@16 dropped long-deprecated support for positional arguments, please pass an object instead.");let{schema:t,document:n,variableValues:r,rootValue:i}=e;ks(t,n,r);let o=Cs(e);if(!("schema"in o))return{errors:o};try{let{operation:s}=o,a=Ms(o,s,i);return se(a)?a.then(c=>En(c,o.errors),c=>(o.errors.push(c),En(null,o.errors))):En(a,o.errors)}catch(s){return o.errors.push(s),En(null,o.errors)}}function En(e,t){return t.length===0?{data:e}:{errors:t,data:e}}function ks(e,t,n){t||R(!1,"Must provide document."),Rt(e),n==null||j(n)||R(!1,"Variables must be provided as an Object where each property is a variable value. Perhaps look to see if an unparsed JSON string was provided.")}function Cs(e){var t,n;let{schema:r,document:i,rootValue:o,contextValue:s,variableValues:a,operationName:c,fieldResolver:p,typeResolver:l,subscribeFieldResolver:d}=e,h,T=Object.create(null);for(let k of i.definitions)switch(k.kind){case u.OPERATION_DEFINITION:if(c==null){if(h!==void 0)return[new f("Must provide operation name if query contains multiple operations.")];h=k}else((t=k.name)===null||t===void 0?void 0:t.value)===c&&(h=k);break;case u.FRAGMENT_DEFINITION:T[k.name.value]=k;break;default:}if(!h)return c!=null?[new f(`Unknown operation named "${c}".`)]:[new f("Must provide an operation.")];let g=(n=h.variableDefinitions)!==null&&n!==void 0?n:[],D=xr(r,g,a??{},{maxErrors:50});return D.errors?D.errors:{schema:r,fragments:T,rootValue:o,contextValue:s,operation:h,variableValues:D.coerced,fieldResolver:p??In,typeResolver:l??Jr,subscribeFieldResolver:d??In,errors:[]}}function Ms(e,t,n){let r=e.schema.getRootType(t.operation);if(r==null)throw new f(`Schema is not configured to execute ${t.operation} operation.`,{nodes:t});let i=mn(e.schema,e.fragments,e.variableValues,r,t.selectionSet),o=void 0;switch(t.operation){case F.QUERY:return vn(e,r,n,o,i);case F.MUTATION:return Ps(e,r,n,o,i);case F.SUBSCRIPTION:return vn(e,r,n,o,i)}}function Ps(e,t,n,r,i){return zi(i.entries(),(o,[s,a])=>{let c=Pe(r,s,t.name),p=Zi(e,t,n,a,c);return p===void 0?o:se(p)?p.then(l=>(o[s]=l,o)):(o[s]=p,o)},Object.create(null))}function vn(e,t,n,r,i){let o=Object.create(null),s=!1;try{for(let[a,c]of i.entries()){let p=Pe(r,a,t.name),l=Zi(e,t,n,c,p);l!==void 0&&(o[a]=l,se(l)&&(s=!0))}}catch(a){if(s)return qr(o).finally(()=>{throw a});throw a}return s?qr(o):o}function Zi(e,t,n,r,i){var o;let s=js(e.schema,t,r[0]);if(!s)return;let a=s.type,c=(o=s.resolve)!==null&&o!==void 0?o:e.fieldResolver,p=Us(e,s,r,t,i);try{let l=ln(s,r[0],e.variableValues),d=e.contextValue,h=c(n,l,d,p),T;return se(h)?T=h.then(g=>xt(e,a,r,p,i,g)):T=xt(e,a,r,p,i,h),se(T)?T.then(void 0,g=>{let D=_t(g,r,W(i));return Nn(D,a,e)}):T}catch(l){let d=_t(l,r,W(i));return Nn(d,a,e)}}function Us(e,t,n,r,i){return{fieldName:t.name,fieldNodes:n,returnType:t.type,parentType:r,path:i,schema:e.schema,fragments:e.fragments,rootValue:e.rootValue,operation:e.operation,variableValues:e.variableValues}}function Nn(e,t,n){if(b(t))throw e;return n.errors.push(e),null}function xt(e,t,n,r,i,o){if(o instanceof Error)throw o;if(b(t)){let s=xt(e,t.ofType,n,r,i,o);if(s===null)throw new Error(`Cannot return null for non-nullable field ${r.parentType.name}.${r.fieldName}.`);return s}if(o==null)return null;if(w(t))return $s(e,t,n,r,i,o);if(J(t))return Vs(t,o);if(ne(t))return Gs(e,t,n,r,i,o);if(O(t))return Hr(e,t,n,r,i,o);C(!1,"Cannot complete value of unexpected output type: "+y(t))}function $s(e,t,n,r,i,o){if(!Ze(o))throw new f(`Expected Iterable, but did not find one for field "${r.parentType.name}.${r.fieldName}".`);let s=t.ofType,a=!1,c=Array.from(o,(p,l)=>{let d=Pe(i,l,void 0);try{let h;return se(p)?h=p.then(T=>xt(e,s,n,r,d,T)):h=xt(e,s,n,r,d,p),se(h)?(a=!0,h.then(void 0,T=>{let g=_t(T,n,W(d));return Nn(g,s,e)})):h}catch(h){let T=_t(h,n,W(d));return Nn(T,s,e)}});return a?Promise.all(c):c}function Vs(e,t){let n=e.serialize(t);if(n==null)throw new Error(`Expected \`${y(e)}.serialize(${y(t)})\` to return non-nullable value, returned: ${y(n)}`);return n}function Gs(e,t,n,r,i,o){var s;let a=(s=t.resolveType)!==null&&s!==void 0?s:e.typeResolver,c=e.contextValue,p=a(o,c,r,t);return se(p)?p.then(l=>Hr(e,Ki(l,e,t,n,r,o),n,r,i,o)):Hr(e,Ki(p,e,t,n,r,o),n,r,i,o)}function Ki(e,t,n,r,i,o){if(e==null)throw new f(`Abstract type "${n.name}" must resolve to an Object type at runtime for field "${i.parentType.name}.${i.fieldName}". Either the "${n.name}" type should provide a "resolveType" function or each possible type should provide an "isTypeOf" function.`,r);if(O(e))throw new f("Support for returning GraphQLObjectType from resolveType was removed in graphql-js@16.0.0 please return type name instead.");if(typeof e!="string")throw new f(`Abstract type "${n.name}" must resolve to an Object type at runtime for field "${i.parentType.name}.${i.fieldName}" with value ${y(o)}, received "${y(e)}".`);let s=t.schema.getType(e);if(s==null)throw new f(`Abstract type "${n.name}" was resolved to a type "${e}" that does not exist inside the schema.`,{nodes:r});if(!O(s))throw new f(`Abstract type "${n.name}" was resolved to a non-object type "${e}".`,{nodes:r});if(!t.schema.isSubType(n,s))throw new f(`Runtime Object type "${s.name}" is not a possible type for "${n.name}".`,{nodes:r});return s}function Hr(e,t,n,r,i,o){let s=Fs(e,t,n);if(t.isTypeOf){let a=t.isTypeOf(o,e.contextValue,r);if(se(a))return a.then(c=>{if(!c)throw Wi(t,o,n);return vn(e,t,o,i,s)});if(!a)throw Wi(t,o,n)}return vn(e,t,o,i,s)}function Wi(e,t,n){return new f(`Expected value of type "${e.name}" but got: ${y(t)}.`,{nodes:n})}var Jr=function(e,t,n,r){if(j(e)&&typeof e.__typename=="string")return e.__typename;let i=n.schema.getPossibleTypes(r),o=[];for(let s=0;s<i.length;s++){let a=i[s];if(a.isTypeOf){let c=a.isTypeOf(e,t,n);if(se(c))o[s]=c;else if(c)return a.name}}if(o.length)return Promise.all(o).then(s=>{for(let a=0;a<s.length;a++)if(s[a])return i[a].name})},In=function(e,t,n,r){if(j(e)||typeof e=="function"){let i=e[r.fieldName];return typeof i=="function"?e[r.fieldName](t,n,r):i}};function js(e,t,n){let r=n.name.value;return r===Ae.name&&e.getQueryType()===t?Ae:r===Fe.name&&e.getQueryType()===t?Fe:r===ke.name?ke:t.getFields()[r]}import{OperationOutcomeError as z,Operator as la,allOk as eo,badRequest as Se,created as to,deepClone as it,evalFhirPath as no,generateId as ro,globalSchema as fa,matchesSearchRequest as da,multipleMatches as zr,normalizeOperationOutcome as ma,notFound as Rn,preconditionFailed as ha,stringify as ya}from"@medplum/core";import{applyPatch as Ta}from"rfc6902";var On={READER:"reader",WRITER:"writer"},Xr=class{async searchOne(t){return(await this.search({...t,count:1})).entry?.[0]?.resource}async searchResources(t){return(await this.search(t)).entry?.map(r=>r.resource)??[]}async conditionalCreate(t,n,r){if(n.resourceType!==t.resourceType)throw new z(Se("Search type must match resource type for conditional update"));return n.count=2,n.sortRules=void 0,this.withTransaction(async()=>{let i=await this.searchResources(n);if(i.length===1){let o=i[0];if(!r?.assignedId&&t.id&&t.id!==o.id)throw new z(Se("Resource ID did not match resolved ID",t.resourceType+".id"));return{resource:i[0],outcome:eo}}else if(i.length>1)throw new z(zr);return t=await this.createResource(t,r),{resource:t,outcome:to}},{serializable:!0})}async conditionalUpdate(t,n,r){if(n.resourceType!==t.resourceType)throw new z(Se("Search type must match resource type for conditional update"));return n.count=2,n.sortRules=void 0,this.withTransaction(async()=>{let i=await this.searchResources(n);if(i.length===0){if(t.id&&!r?.assignedId)throw new z(Se("Cannot perform create as update with client-assigned ID",t.resourceType+".id"));return t=await this.createResource(t,r),{resource:t,outcome:to}}else if(i.length>1)throw new z(zr);let o=i[0];if(t.id&&t.id!==o.id)throw new z(Se("Resource ID did not match resolved ID",t.resourceType+".id"));return t.id=o.id,t=await this.updateResource(t,r),{resource:t,outcome:eo}},{serializable:!0})}async conditionalDelete(t){t.count=2,t.sortRules=void 0,await this.withTransaction(async()=>{let n=await this.searchResources(t);if(n.length>1)throw new z(zr);if(!n.length)return;let r=n[0];await this.deleteResource(r.resourceType,r.id)})}},io=class extends Xr{constructor(){super(),this.resources=new Map,this.history=new Map}clear(){this.resources.clear(),this.history.clear()}setMode(t){}async createResource(t){let n=JSON.parse(ya(t));n.id||(n.id=this.generateId()),n.meta||(n.meta={}),n.meta.versionId||(n.meta.versionId=ro()),n.meta.lastUpdated||(n.meta.lastUpdated=new Date().toISOString());let{resourceType:r,id:i}=n,o=this.resources.get(r);o||(o=new Map,this.resources.set(r,o)),o.set(i,n);let s=this.history.get(r);s||(s=new Map,this.history.set(r,s));let a=s.get(i);return a||(a=[],s.set(i,a)),a.push(n),it(n)}generateId(){return ro()}updateResource(t,n){if(!t.id)throw new z(Se("Missing id"));if(n?.ifMatch){let i=n.ifMatch,o=this.resources.get(t.resourceType)?.get(t.id);if(!o)throw new z(Rn);if(o.meta?.versionId!==i)throw new z(ha)}let r=it(t);return r.meta&&(r.meta.versionId&&delete r.meta.versionId,r.meta.lastUpdated&&delete r.meta.lastUpdated),this.createResource(r)}async patchResource(t,n,r){let i=await this.readResource(t,n);try{let o=Ta(i,r).filter(Boolean);if(o.length>0)throw new z(Se(o.map(s=>s.message).join(`
53
+ `))}var er=class{constructor(t){this._errors=[],this.schema=t}reportError(t,n){let r=Array.isArray(n)?n.filter(Boolean):n;this._errors.push(new f(t,{nodes:r}))}getErrors(){return this._errors}};function Ko(e){let t=e.schema,n=t.getQueryType();if(!n)e.reportError("Query root type must be provided.",t.astNode);else if(!O(n)){var r;e.reportError(`Query root type must be Object type, it cannot be ${y(n)}.`,(r=Zn(t,F.QUERY))!==null&&r!==void 0?r:n.astNode)}let i=t.getMutationType();if(i&&!O(i)){var o;e.reportError(`Mutation root type must be Object type if provided, it cannot be ${y(i)}.`,(o=Zn(t,F.MUTATION))!==null&&o!==void 0?o:i.astNode)}let s=t.getSubscriptionType();if(s&&!O(s)){var a;e.reportError(`Subscription root type must be Object type if provided, it cannot be ${y(s)}.`,(a=Zn(t,F.SUBSCRIPTION))!==null&&a!==void 0?a:s.astNode)}}function Zn(e,t){var n;return(n=[e.astNode,...e.extensionASTNodes].flatMap(r=>{var i;return(i=r?.operationTypes)!==null&&i!==void 0?i:[]}).find(r=>r.operation===t))===null||n===void 0?void 0:n.type}function Wo(e){for(let n of e.schema.getDirectives()){if(!vt(n)){e.reportError(`Expected directive but got: ${y(n)}.`,n?.astNode);continue}Me(e,n),n.locations.length===0&&e.reportError(`Directive @${n.name} must include 1 or more locations.`,n.astNode);for(let r of n.args)if(Me(e,r),H(r.type)||e.reportError(`The type of @${n.name}(${r.name}:) must be Input Type but got: ${y(r.type)}.`,r.astNode),Ie(r)&&r.deprecationReason!=null){var t;e.reportError(`Required argument @${n.name}(${r.name}:) cannot be deprecated.`,[tr(r.astNode),(t=r.astNode)===null||t===void 0?void 0:t.type])}}}function Me(e,t){t.name.startsWith("__")&&e.reportError(`Name "${t.name}" must not begin with "__", which is reserved by GraphQL introspection.`,t.astNode)}function Zo(e){let t=ss(e),n=e.schema.getTypeMap();for(let r of Object.values(n)){if(!Bt(r)){e.reportError(`Expected GraphQL named type but got: ${y(r)}.`,r.astNode);continue}Kn(r)||Me(e,r),O(r)||_(r)?(ki(e,r),Ci(e,r)):Y(r)?ns(e,r):$(r)?rs(e,r):L(r)&&(is(e,r),t(r))}}function ki(e,t){let n=Object.values(t.getFields());n.length===0&&e.reportError(`Type ${t.name} must define one or more fields.`,[t.astNode,...t.extensionASTNodes]);for(let s of n){if(Me(e,s),!Ne(s.type)){var r;e.reportError(`The type of ${t.name}.${s.name} must be Output Type but got: ${y(s.type)}.`,(r=s.astNode)===null||r===void 0?void 0:r.type)}for(let a of s.args){let c=a.name;if(Me(e,a),!H(a.type)){var i;e.reportError(`The type of ${t.name}.${s.name}(${c}:) must be Input Type but got: ${y(a.type)}.`,(i=a.astNode)===null||i===void 0?void 0:i.type)}if(Ie(a)&&a.deprecationReason!=null){var o;e.reportError(`Required argument ${t.name}.${s.name}(${c}:) cannot be deprecated.`,[tr(a.astNode),(o=a.astNode)===null||o===void 0?void 0:o.type])}}}}function Ci(e,t){let n=Object.create(null);for(let r of t.getInterfaces()){if(!_(r)){e.reportError(`Type ${y(t)} must only implement Interface types, it cannot implement ${y(r)}.`,bt(t,r));continue}if(t===r){e.reportError(`Type ${t.name} cannot implement itself because it would create a circular reference.`,bt(t,r));continue}if(n[r.name]){e.reportError(`Type ${t.name} can only implement ${r.name} once.`,bt(t,r));continue}n[r.name]=!0,ts(e,t,r),es(e,t,r)}}function es(e,t,n){let r=t.getFields();for(let c of Object.values(n.getFields())){let p=c.name,l=r[p];if(!l){e.reportError(`Interface field ${n.name}.${p} expected but ${t.name} does not provide it.`,[c.astNode,t.astNode,...t.extensionASTNodes]);continue}if(!Re(e.schema,l.type,c.type)){var i,o;e.reportError(`Interface field ${n.name}.${p} expects type ${y(c.type)} but ${t.name}.${p} is type ${y(l.type)}.`,[(i=c.astNode)===null||i===void 0?void 0:i.type,(o=l.astNode)===null||o===void 0?void 0:o.type])}for(let d of c.args){let h=d.name,T=l.args.find(g=>g.name===h);if(!T){e.reportError(`Interface field argument ${n.name}.${p}(${h}:) expected but ${t.name}.${p} does not provide it.`,[d.astNode,l.astNode]);continue}if(!Ht(d.type,T.type)){var s,a;e.reportError(`Interface field argument ${n.name}.${p}(${h}:) expects type ${y(d.type)} but ${t.name}.${p}(${h}:) is type ${y(T.type)}.`,[(s=d.astNode)===null||s===void 0?void 0:s.type,(a=T.astNode)===null||a===void 0?void 0:a.type])}}for(let d of l.args){let h=d.name;!c.args.find(g=>g.name===h)&&Ie(d)&&e.reportError(`Object field ${t.name}.${p} includes required argument ${h} that is missing from the Interface field ${n.name}.${p}.`,[d.astNode,c.astNode])}}}function ts(e,t,n){let r=t.getInterfaces();for(let i of n.getInterfaces())r.includes(i)||e.reportError(i===t?`Type ${t.name} cannot implement ${n.name} because it would create a circular reference.`:`Type ${t.name} must implement ${i.name} because it is implemented by ${n.name}.`,[...bt(n,i),...bt(t,n)])}function ns(e,t){let n=t.getTypes();n.length===0&&e.reportError(`Union type ${t.name} must define one or more member types.`,[t.astNode,...t.extensionASTNodes]);let r=Object.create(null);for(let i of n){if(r[i.name]){e.reportError(`Union type ${t.name} can only include type ${i.name} once.`,Mi(t,i.name));continue}r[i.name]=!0,O(i)||e.reportError(`Union type ${t.name} can only include Object types, it cannot include ${y(i)}.`,Mi(t,String(i)))}}function rs(e,t){let n=t.getValues();n.length===0&&e.reportError(`Enum type ${t.name} must define one or more values.`,[t.astNode,...t.extensionASTNodes]);for(let r of n)Me(e,r)}function is(e,t){let n=Object.values(t.getFields());n.length===0&&e.reportError(`Input Object type ${t.name} must define one or more fields.`,[t.astNode,...t.extensionASTNodes]);for(let o of n){if(Me(e,o),!H(o.type)){var r;e.reportError(`The type of ${t.name}.${o.name} must be Input Type but got: ${y(o.type)}.`,(r=o.astNode)===null||r===void 0?void 0:r.type)}if(We(o)&&o.deprecationReason!=null){var i;e.reportError(`Required input field ${t.name}.${o.name} cannot be deprecated.`,[tr(o.astNode),(i=o.astNode)===null||i===void 0?void 0:i.type])}t.isOneOf&&os(t,o,e)}}function os(e,t,n){if(b(t.type)){var r;n.reportError(`OneOf input field ${e.name}.${t.name} must be nullable.`,(r=t.astNode)===null||r===void 0?void 0:r.type)}t.defaultValue!==void 0&&n.reportError(`OneOf input field ${e.name}.${t.name} cannot have a default value.`,t.astNode)}function ss(e){let t=Object.create(null),n=[],r=Object.create(null);return i;function i(o){if(t[o.name])return;t[o.name]=!0,r[o.name]=n.length;let s=Object.values(o.getFields());for(let a of s)if(b(a.type)&&L(a.type.ofType)){let c=a.type.ofType,p=r[c.name];if(n.push(a),p===void 0)i(c);else{let l=n.slice(p),d=l.map(h=>h.name).join(".");e.reportError(`Cannot reference Input Object "${c.name}" within itself through a series of non-null fields: "${d}".`,l.map(h=>h.astNode))}n.pop()}r[o.name]=void 0}}function bt(e,t){let{astNode:n,extensionASTNodes:r}=e;return(n!=null?[n,...r]:r).flatMap(o=>{var s;return(s=o.interfaces)!==null&&s!==void 0?s:[]}).filter(o=>o.name.value===t.name)}function Mi(e,t){let{astNode:n,extensionASTNodes:r}=e;return(n!=null?[n,...r]:r).flatMap(o=>{var s;return(s=o.types)!==null&&s!==void 0?s:[]}).filter(o=>o.name.value===t)}function tr(e){var t;return e==null||(t=e.directives)===null||t===void 0?void 0:t.find(n=>n.name.value===Kt.name)}function M(e,t){switch(t.kind){case u.LIST_TYPE:{let n=M(e,t.type);return n&&new A(n)}case u.NON_NULL_TYPE:{let n=M(e,t.type);return n&&new I(n)}case u.NAMED_TYPE:return e.getType(t.name.value)}}var tt=class{constructor(t,n,r){this._schema=t,this._typeStack=[],this._parentTypeStack=[],this._inputTypeStack=[],this._fieldDefStack=[],this._defaultValueStack=[],this._directive=null,this._argument=null,this._enumValue=null,this._getFieldDef=r??as,n&&(H(n)&&this._inputTypeStack.push(n),ae(n)&&this._parentTypeStack.push(n),Ne(n)&&this._typeStack.push(n))}get[Symbol.toStringTag](){return"TypeInfo"}getType(){if(this._typeStack.length>0)return this._typeStack[this._typeStack.length-1]}getParentType(){if(this._parentTypeStack.length>0)return this._parentTypeStack[this._parentTypeStack.length-1]}getInputType(){if(this._inputTypeStack.length>0)return this._inputTypeStack[this._inputTypeStack.length-1]}getParentInputType(){if(this._inputTypeStack.length>1)return this._inputTypeStack[this._inputTypeStack.length-2]}getFieldDef(){if(this._fieldDefStack.length>0)return this._fieldDefStack[this._fieldDefStack.length-1]}getDefaultValue(){if(this._defaultValueStack.length>0)return this._defaultValueStack[this._defaultValueStack.length-1]}getDirective(){return this._directive}getArgument(){return this._argument}getEnumValue(){return this._enumValue}enter(t){let n=this._schema;switch(t.kind){case u.SELECTION_SET:{let i=q(this.getType());this._parentTypeStack.push(ae(i)?i:void 0);break}case u.FIELD:{let i=this.getParentType(),o,s;i&&(o=this._getFieldDef(n,i,t),o&&(s=o.type)),this._fieldDefStack.push(o),this._typeStack.push(Ne(s)?s:void 0);break}case u.DIRECTIVE:this._directive=n.getDirective(t.name.value);break;case u.OPERATION_DEFINITION:{let i=n.getRootType(t.operation);this._typeStack.push(O(i)?i:void 0);break}case u.INLINE_FRAGMENT:case u.FRAGMENT_DEFINITION:{let i=t.typeCondition,o=i?M(n,i):q(this.getType());this._typeStack.push(Ne(o)?o:void 0);break}case u.VARIABLE_DEFINITION:{let i=M(n,t.type);this._inputTypeStack.push(H(i)?i:void 0);break}case u.ARGUMENT:{var r;let i,o,s=(r=this.getDirective())!==null&&r!==void 0?r:this.getFieldDef();s&&(i=s.args.find(a=>a.name===t.name.value),i&&(o=i.type)),this._argument=i,this._defaultValueStack.push(i?i.defaultValue:void 0),this._inputTypeStack.push(H(o)?o:void 0);break}case u.LIST:{let i=Ke(this.getInputType()),o=w(i)?i.ofType:i;this._defaultValueStack.push(void 0),this._inputTypeStack.push(H(o)?o:void 0);break}case u.OBJECT_FIELD:{let i=q(this.getInputType()),o,s;L(i)&&(s=i.getFields()[t.name.value],s&&(o=s.type)),this._defaultValueStack.push(s?s.defaultValue:void 0),this._inputTypeStack.push(H(o)?o:void 0);break}case u.ENUM:{let i=q(this.getInputType()),o;$(i)&&(o=i.getValue(t.value)),this._enumValue=o;break}default:}}leave(t){switch(t.kind){case u.SELECTION_SET:this._parentTypeStack.pop();break;case u.FIELD:this._fieldDefStack.pop(),this._typeStack.pop();break;case u.DIRECTIVE:this._directive=null;break;case u.OPERATION_DEFINITION:case u.INLINE_FRAGMENT:case u.FRAGMENT_DEFINITION:this._typeStack.pop();break;case u.VARIABLE_DEFINITION:this._inputTypeStack.pop();break;case u.ARGUMENT:this._argument=null,this._defaultValueStack.pop(),this._inputTypeStack.pop();break;case u.LIST:case u.OBJECT_FIELD:this._defaultValueStack.pop(),this._inputTypeStack.pop();break;case u.ENUM:this._enumValue=null;break;default:}}};function as(e,t,n){let r=n.name.value;if(r===Ae.name&&e.getQueryType()===t)return Ae;if(r===Fe.name&&e.getQueryType()===t)return Fe;if(r===ke.name&&ae(t))return ke;if(O(t)||_(t))return t.getFields()[r]}function en(e,t){return{enter(...n){let r=n[0];e.enter(r);let i=Je(t,r.kind).enter;if(i){let o=i.apply(t,n);return o!==void 0&&(e.leave(r),ut(o)&&e.enter(o)),o}},leave(...n){let r=n[0],i=Je(t,r.kind).leave,o;return i&&(o=i.apply(t,n)),e.leave(r),o}}}function nr(e){return e.kind===u.OPERATION_DEFINITION||e.kind===u.FRAGMENT_DEFINITION}function rr(e){return e.kind===u.SCHEMA_DEFINITION||Oe(e)||e.kind===u.DIRECTIVE_DEFINITION}function Oe(e){return e.kind===u.SCALAR_TYPE_DEFINITION||e.kind===u.OBJECT_TYPE_DEFINITION||e.kind===u.INTERFACE_TYPE_DEFINITION||e.kind===u.UNION_TYPE_DEFINITION||e.kind===u.ENUM_TYPE_DEFINITION||e.kind===u.INPUT_OBJECT_TYPE_DEFINITION}function ir(e){return e.kind===u.SCHEMA_EXTENSION||tn(e)}function tn(e){return e.kind===u.SCALAR_TYPE_EXTENSION||e.kind===u.OBJECT_TYPE_EXTENSION||e.kind===u.INTERFACE_TYPE_EXTENSION||e.kind===u.UNION_TYPE_EXTENSION||e.kind===u.ENUM_TYPE_EXTENSION||e.kind===u.INPUT_OBJECT_TYPE_EXTENSION}function or(e){return{Document(t){for(let n of t.definitions)if(!nr(n)){let r=n.kind===u.SCHEMA_DEFINITION||n.kind===u.SCHEMA_EXTENSION?"schema":'"'+n.name.value+'"';e.reportError(new f(`The ${r} definition is not executable.`,{nodes:n}))}return!1}}}function sr(e){return{Field(t){let n=e.getParentType();if(n&&!e.getFieldDef()){let i=e.getSchema(),o=t.name.value,s=K("to use an inline fragment on",cs(i,n,o));s===""&&(s=K(us(n,o))),e.reportError(new f(`Cannot query field "${o}" on type "${n.name}".`+s,{nodes:t}))}}}}function cs(e,t,n){if(!ne(t))return[];let r=new Set,i=Object.create(null);for(let s of e.getPossibleTypes(t))if(s.getFields()[n]){r.add(s),i[s.name]=1;for(let a of s.getInterfaces()){var o;a.getFields()[n]&&(r.add(a),i[a.name]=((o=i[a.name])!==null&&o!==void 0?o:0)+1)}}return[...r].sort((s,a)=>{let c=i[a.name]-i[s.name];return c!==0?c:_(s)&&e.isSubType(s,a)?-1:_(a)&&e.isSubType(a,s)?1:Ye(s.name,a.name)}).map(s=>s.name)}function us(e,t){if(O(e)||_(e)){let n=Object.keys(e.getFields());return ee(t,n)}return[]}function ar(e){return{InlineFragment(t){let n=t.typeCondition;if(n){let r=M(e.getSchema(),n);if(r&&!ae(r)){let i=x(n);e.reportError(new f(`Fragment cannot condition on non composite type "${i}".`,{nodes:n}))}}},FragmentDefinition(t){let n=M(e.getSchema(),t.typeCondition);if(n&&!ae(n)){let r=x(t.typeCondition);e.reportError(new f(`Fragment "${t.name.value}" cannot condition on non composite type "${r}".`,{nodes:t.typeCondition}))}}}}function cr(e){return{...ur(e),Argument(t){let n=e.getArgument(),r=e.getFieldDef(),i=e.getParentType();if(!n&&r&&i){let o=t.name.value,s=r.args.map(c=>c.name),a=ee(o,s);e.reportError(new f(`Unknown argument "${o}" on field "${i.name}.${r.name}".`+K(a),{nodes:t}))}}}}function ur(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():Te;for(let s of r)t[s.name]=s.args.map(a=>a.name);let i=e.getDocument().definitions;for(let s of i)if(s.kind===u.DIRECTIVE_DEFINITION){var o;let a=(o=s.arguments)!==null&&o!==void 0?o:[];t[s.name.value]=a.map(c=>c.name.value)}return{Directive(s){let a=s.name.value,c=t[a];if(s.arguments&&c)for(let p of s.arguments){let l=p.name.value;if(!c.includes(l)){let d=ee(l,c);e.reportError(new f(`Unknown argument "${l}" on directive "@${a}".`+K(d),{nodes:p}))}}return!1}}}function nn(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():Te;for(let o of r)t[o.name]=o.locations;let i=e.getDocument().definitions;for(let o of i)o.kind===u.DIRECTIVE_DEFINITION&&(t[o.name.value]=o.locations.map(s=>s.value));return{Directive(o,s,a,c,p){let l=o.name.value,d=t[l];if(!d){e.reportError(new f(`Unknown directive "@${l}".`,{nodes:o}));return}let h=ps(p);h&&!d.includes(h)&&e.reportError(new f(`Directive "@${l}" may not be used on ${h}.`,{nodes:o}))}}}function ps(e){let t=e[e.length-1];switch("kind"in t||C(!1),t.kind){case u.OPERATION_DEFINITION:return ls(t.operation);case u.FIELD:return N.FIELD;case u.FRAGMENT_SPREAD:return N.FRAGMENT_SPREAD;case u.INLINE_FRAGMENT:return N.INLINE_FRAGMENT;case u.FRAGMENT_DEFINITION:return N.FRAGMENT_DEFINITION;case u.VARIABLE_DEFINITION:return N.VARIABLE_DEFINITION;case u.SCHEMA_DEFINITION:case u.SCHEMA_EXTENSION:return N.SCHEMA;case u.SCALAR_TYPE_DEFINITION:case u.SCALAR_TYPE_EXTENSION:return N.SCALAR;case u.OBJECT_TYPE_DEFINITION:case u.OBJECT_TYPE_EXTENSION:return N.OBJECT;case u.FIELD_DEFINITION:return N.FIELD_DEFINITION;case u.INTERFACE_TYPE_DEFINITION:case u.INTERFACE_TYPE_EXTENSION:return N.INTERFACE;case u.UNION_TYPE_DEFINITION:case u.UNION_TYPE_EXTENSION:return N.UNION;case u.ENUM_TYPE_DEFINITION:case u.ENUM_TYPE_EXTENSION:return N.ENUM;case u.ENUM_VALUE_DEFINITION:return N.ENUM_VALUE;case u.INPUT_OBJECT_TYPE_DEFINITION:case u.INPUT_OBJECT_TYPE_EXTENSION:return N.INPUT_OBJECT;case u.INPUT_VALUE_DEFINITION:{let n=e[e.length-3];return"kind"in n||C(!1),n.kind===u.INPUT_OBJECT_TYPE_DEFINITION?N.INPUT_FIELD_DEFINITION:N.ARGUMENT_DEFINITION}default:C(!1,"Unexpected kind: "+y(t.kind))}}function ls(e){switch(e){case F.QUERY:return N.QUERY;case F.MUTATION:return N.MUTATION;case F.SUBSCRIPTION:return N.SUBSCRIPTION}}function pr(e){return{FragmentSpread(t){let n=t.name.value;e.getFragment(n)||e.reportError(new f(`Unknown fragment "${n}".`,{nodes:t.name}))}}}function rn(e){let t=e.getSchema(),n=t?t.getTypeMap():Object.create(null),r=Object.create(null);for(let o of e.getDocument().definitions)Oe(o)&&(r[o.name.value]=!0);let i=[...Object.keys(n),...Object.keys(r)];return{NamedType(o,s,a,c,p){let l=o.name.value;if(!n[l]&&!r[l]){var d;let h=(d=p[2])!==null&&d!==void 0?d:a,T=h!=null&&fs(h);if(T&&Ui.includes(l))return;let g=ee(l,T?Ui.concat(i):i);e.reportError(new f(`Unknown type "${l}".`+K(g),{nodes:o}))}}}}var Ui=[...Jt,...Wt].map(e=>e.name);function fs(e){return"kind"in e&&(rr(e)||ir(e))}function lr(e){let t=0;return{Document(n){t=n.definitions.filter(r=>r.kind===u.OPERATION_DEFINITION).length},OperationDefinition(n){!n.name&&t>1&&e.reportError(new f("This anonymous operation must be the only defined operation.",{nodes:n}))}}}function fr(e){var t,n,r;let i=e.getSchema(),o=(t=(n=(r=i?.astNode)!==null&&r!==void 0?r:i?.getQueryType())!==null&&n!==void 0?n:i?.getMutationType())!==null&&t!==void 0?t:i?.getSubscriptionType(),s=0;return{SchemaDefinition(a){if(o){e.reportError(new f("Cannot define a new schema within a schema extension.",{nodes:a}));return}s>0&&e.reportError(new f("Must provide only one schema definition.",{nodes:a})),++s}}}var ds=3;function dr(e){function t(n,r=Object.create(null),i=0){if(n.kind===u.FRAGMENT_SPREAD){let o=n.name.value;if(r[o]===!0)return!1;let s=e.getFragment(o);if(!s)return!1;try{return r[o]=!0,t(s,r,i)}finally{r[o]=void 0}}if(n.kind===u.FIELD&&(n.name.value==="fields"||n.name.value==="interfaces"||n.name.value==="possibleTypes"||n.name.value==="inputFields")&&(i++,i>=ds))return!0;if("selectionSet"in n&&n.selectionSet){for(let o of n.selectionSet.selections)if(t(o,r,i))return!0}return!1}return{Field(n){if((n.name.value==="__schema"||n.name.value==="__type")&&t(n))return e.reportError(new f("Maximum introspection depth exceeded",{nodes:[n]})),!1}}}function mr(e){let t=Object.create(null),n=[],r=Object.create(null);return{OperationDefinition:()=>!1,FragmentDefinition(o){return i(o),!1}};function i(o){if(t[o.name.value])return;let s=o.name.value;t[s]=!0;let a=e.getFragmentSpreads(o.selectionSet);if(a.length!==0){r[s]=n.length;for(let c of a){let p=c.name.value,l=r[p];if(n.push(c),l===void 0){let d=e.getFragment(p);d&&i(d)}else{let d=n.slice(l),h=d.slice(0,-1).map(T=>'"'+T.name.value+'"').join(", ");e.reportError(new f(`Cannot spread fragment "${p}" within itself`+(h!==""?` via ${h}.`:"."),{nodes:d}))}n.pop()}r[s]=void 0}}}function hr(e){let t=Object.create(null);return{OperationDefinition:{enter(){t=Object.create(null)},leave(n){let r=e.getRecursiveVariableUsages(n);for(let{node:i}of r){let o=i.name.value;t[o]!==!0&&e.reportError(new f(n.name?`Variable "$${o}" is not defined by operation "${n.name.value}".`:`Variable "$${o}" is not defined.`,{nodes:[i,n]}))}}},VariableDefinition(n){t[n.variable.name.value]=!0}}}function yr(e){let t=[],n=[];return{OperationDefinition(r){return t.push(r),!1},FragmentDefinition(r){return n.push(r),!1},Document:{leave(){let r=Object.create(null);for(let i of t)for(let o of e.getRecursivelyReferencedFragments(i))r[o.name.value]=!0;for(let i of n){let o=i.name.value;r[o]!==!0&&e.reportError(new f(`Fragment "${o}" is never used.`,{nodes:i}))}}}}}function Tr(e){let t=[];return{OperationDefinition:{enter(){t=[]},leave(n){let r=Object.create(null),i=e.getRecursiveVariableUsages(n);for(let{node:o}of i)r[o.name.value]=!0;for(let o of t){let s=o.variable.name.value;r[s]!==!0&&e.reportError(new f(n.name?`Variable "$${s}" is never used in operation "${n.name.value}".`:`Variable "$${s}" is never used.`,{nodes:o}))}}},VariableDefinition(n){t.push(n)}}}function on(e){switch(e.kind){case u.OBJECT:return{...e,fields:ms(e.fields)};case u.LIST:return{...e,values:e.values.map(on)};case u.INT:case u.FLOAT:case u.STRING:case u.BOOLEAN:case u.NULL:case u.ENUM:case u.VARIABLE:return e}}function ms(e){return e.map(t=>({...t,value:on(t.value)})).sort((t,n)=>Ye(t.name.value,n.name.value))}function Vi(e){return Array.isArray(e)?e.map(([t,n])=>`subfields "${t}" conflict because `+Vi(n)).join(" and "):e}function Nr(e){let t=new un,n=new vr,r=new Map;return{SelectionSet(i){let o=hs(e,r,t,n,e.getParentType(),i);for(let[[s,a],c,p]of o){let l=Vi(a);e.reportError(new f(`Fields "${s}" conflict because ${l}. Use different aliases on the fields to fetch both if this was intentional.`,{nodes:c.concat(p)}))}}}}function hs(e,t,n,r,i,o){let s=[],[a,c]=cn(e,t,i,o);if(Ts(e,s,t,n,r,a),c.length!==0)for(let p=0;p<c.length;p++){sn(e,s,t,n,r,!1,a,c[p]);for(let l=p+1;l<c.length;l++)an(e,s,t,n,r,!1,c[p],c[l])}return s}function sn(e,t,n,r,i,o,s,a){if(r.has(s,a,o))return;r.add(s,a,o);let c=e.getFragment(a);if(!c)return;let[p,l]=Er(e,n,c);if(s!==p){Ir(e,t,n,r,i,o,s,p);for(let d of l)sn(e,t,n,r,i,o,s,d)}}function an(e,t,n,r,i,o,s,a){if(s===a||i.has(s,a,o))return;i.add(s,a,o);let c=e.getFragment(s),p=e.getFragment(a);if(!c||!p)return;let[l,d]=Er(e,n,c),[h,T]=Er(e,n,p);Ir(e,t,n,r,i,o,l,h);for(let g of T)an(e,t,n,r,i,o,s,g);for(let g of d)an(e,t,n,r,i,o,g,a)}function ys(e,t,n,r,i,o,s,a,c){let p=[],[l,d]=cn(e,t,o,s),[h,T]=cn(e,t,a,c);Ir(e,p,t,n,r,i,l,h);for(let g of T)sn(e,p,t,n,r,i,l,g);for(let g of d)sn(e,p,t,n,r,i,h,g);for(let g of d)for(let D of T)an(e,p,t,n,r,i,g,D);return p}function Ts(e,t,n,r,i,o){for(let[s,a]of Object.entries(o))if(a.length>1)for(let c=0;c<a.length;c++)for(let p=c+1;p<a.length;p++){let l=Gi(e,n,r,i,!1,s,a[c],a[p]);l&&t.push(l)}}function Ir(e,t,n,r,i,o,s,a){for(let[c,p]of Object.entries(s)){let l=a[c];if(l)for(let d of p)for(let h of l){let T=Gi(e,n,r,i,o,c,d,h);T&&t.push(T)}}}function Gi(e,t,n,r,i,o,s,a){let[c,p,l]=s,[d,h,T]=a,g=i||c!==d&&O(c)&&O(d);if(!g){let oe=p.name.value,le=h.name.value;if(oe!==le)return[[o,`"${oe}" and "${le}" are different fields`],[p],[h]];if(!gs(p,h))return[[o,"they have differing arguments"],[p],[h]]}let D=l?.type,k=T?.type;if(D&&k&&gr(D,k))return[[o,`they return conflicting types "${y(D)}" and "${y(k)}"`],[p],[h]];let re=p.selectionSet,st=h.selectionSet;if(re&&st){let oe=ys(e,t,n,r,g,q(D),re,q(k),st);return Es(oe,o,p,h)}}function gs(e,t){let n=e.arguments,r=t.arguments;if(n===void 0||n.length===0)return r===void 0||r.length===0;if(r===void 0||r.length===0||n.length!==r.length)return!1;let i=new Map(r.map(({name:o,value:s})=>[o.value,s]));return n.every(o=>{let s=o.value,a=i.get(o.name.value);return a===void 0?!1:$i(s)===$i(a)})}function $i(e){return x(on(e))}function gr(e,t){return w(e)?w(t)?gr(e.ofType,t.ofType):!0:w(t)?!0:b(e)?b(t)?gr(e.ofType,t.ofType):!0:b(t)?!0:J(e)||J(t)?e!==t:!1}function cn(e,t,n,r){let i=t.get(r);if(i)return i;let o=Object.create(null),s=Object.create(null);ji(e,n,r,o,s);let a=[o,Object.keys(s)];return t.set(r,a),a}function Er(e,t,n){let r=t.get(n.selectionSet);if(r)return r;let i=M(e.getSchema(),n.typeCondition);return cn(e,t,i,n.selectionSet)}function ji(e,t,n,r,i){for(let o of n.selections)switch(o.kind){case u.FIELD:{let s=o.name.value,a;(O(t)||_(t))&&(a=t.getFields()[s]);let c=o.alias?o.alias.value:s;r[c]||(r[c]=[]),r[c].push([t,o,a]);break}case u.FRAGMENT_SPREAD:i[o.name.value]=!0;break;case u.INLINE_FRAGMENT:{let s=o.typeCondition,a=s?M(e.getSchema(),s):t;ji(e,a,o.selectionSet,r,i);break}}}function Es(e,t,n,r){if(e.length>0)return[[t,e.map(([i])=>i)],[n,...e.map(([,i])=>i).flat()],[r,...e.map(([,,i])=>i).flat()]]}var un=class{constructor(){this._data=new Map}has(t,n,r){var i;let o=(i=this._data.get(t))===null||i===void 0?void 0:i.get(n);return o===void 0?!1:r?!0:r===o}add(t,n,r){let i=this._data.get(t);i===void 0?this._data.set(t,new Map([[n,r]])):i.set(n,r)}},vr=class{constructor(){this._orderedPairSet=new un}has(t,n,r){return t<n?this._orderedPairSet.has(t,n,r):this._orderedPairSet.has(n,t,r)}add(t,n,r){t<n?this._orderedPairSet.add(t,n,r):this._orderedPairSet.add(n,t,r)}};function br(e){return{InlineFragment(t){let n=e.getType(),r=e.getParentType();if(ae(n)&&ae(r)&&!qn(e.getSchema(),n,r)){let i=y(r),o=y(n);e.reportError(new f(`Fragment cannot be spread here as objects of type "${i}" can never be of type "${o}".`,{nodes:t}))}},FragmentSpread(t){let n=t.name.value,r=vs(e,n),i=e.getParentType();if(r&&i&&!qn(e.getSchema(),r,i)){let o=y(i),s=y(r);e.reportError(new f(`Fragment "${n}" cannot be spread here as objects of type "${o}" can never be of type "${s}".`,{nodes:t}))}}}}function vs(e,t){let n=e.getFragment(t);if(n){let r=M(e.getSchema(),n.typeCondition);if(ae(r))return r}}function Rr(e){let t=e.getSchema(),n=Object.create(null);for(let i of e.getDocument().definitions)Oe(i)&&(n[i.name.value]=i);return{ScalarTypeExtension:r,ObjectTypeExtension:r,InterfaceTypeExtension:r,UnionTypeExtension:r,EnumTypeExtension:r,InputObjectTypeExtension:r};function r(i){let o=i.name.value,s=n[o],a=t?.getType(o),c;if(s?c=Ns[s.kind]:a&&(c=Is(a)),c){if(c!==i.kind){let p=bs(i.kind);e.reportError(new f(`Cannot extend non-${p} type "${o}".`,{nodes:s?[s,i]:i}))}}else{let p=Object.keys({...n,...t?.getTypeMap()}),l=ee(o,p);e.reportError(new f(`Cannot extend type "${o}" because it is not defined.`+K(l),{nodes:i.name}))}}}var Ns={[u.SCALAR_TYPE_DEFINITION]:u.SCALAR_TYPE_EXTENSION,[u.OBJECT_TYPE_DEFINITION]:u.OBJECT_TYPE_EXTENSION,[u.INTERFACE_TYPE_DEFINITION]:u.INTERFACE_TYPE_EXTENSION,[u.UNION_TYPE_DEFINITION]:u.UNION_TYPE_EXTENSION,[u.ENUM_TYPE_DEFINITION]:u.ENUM_TYPE_EXTENSION,[u.INPUT_OBJECT_TYPE_DEFINITION]:u.INPUT_OBJECT_TYPE_EXTENSION};function Is(e){if(he(e))return u.SCALAR_TYPE_EXTENSION;if(O(e))return u.OBJECT_TYPE_EXTENSION;if(_(e))return u.INTERFACE_TYPE_EXTENSION;if(Y(e))return u.UNION_TYPE_EXTENSION;if($(e))return u.ENUM_TYPE_EXTENSION;if(L(e))return u.INPUT_OBJECT_TYPE_EXTENSION;C(!1,"Unexpected type: "+y(e))}function bs(e){switch(e){case u.SCALAR_TYPE_EXTENSION:return"scalar";case u.OBJECT_TYPE_EXTENSION:return"object";case u.INTERFACE_TYPE_EXTENSION:return"interface";case u.UNION_TYPE_EXTENSION:return"union";case u.ENUM_TYPE_EXTENSION:return"enum";case u.INPUT_OBJECT_TYPE_EXTENSION:return"input object";default:C(!1,"Unexpected kind: "+y(e))}}function Or(e){return{...Sr(e),Field:{leave(t){var n;let r=e.getFieldDef();if(!r)return!1;let i=new Set((n=t.arguments)===null||n===void 0?void 0:n.map(o=>o.name.value));for(let o of r.args)if(!i.has(o.name)&&Ie(o)){let s=y(o.type);e.reportError(new f(`Field "${r.name}" argument "${o.name}" of type "${s}" is required, but it was not provided.`,{nodes:t}))}}}}}function Sr(e){var t;let n=Object.create(null),r=e.getSchema(),i=(t=r?.getDirectives())!==null&&t!==void 0?t:Te;for(let a of i)n[a.name]=fe(a.args.filter(Ie),c=>c.name);let o=e.getDocument().definitions;for(let a of o)if(a.kind===u.DIRECTIVE_DEFINITION){var s;let c=(s=a.arguments)!==null&&s!==void 0?s:[];n[a.name.value]=fe(c.filter(Rs),p=>p.name.value)}return{Directive:{leave(a){let c=a.name.value,p=n[c];if(p){var l;let d=(l=a.arguments)!==null&&l!==void 0?l:[],h=new Set(d.map(T=>T.name.value));for(let[T,g]of Object.entries(p))if(!h.has(T)){let D=Xe(g.type)?y(g.type):x(g.type);e.reportError(new f(`Directive "@${c}" argument "${T}" of type "${D}" is required, but it was not provided.`,{nodes:a}))}}}}}}function Rs(e){return e.type.kind===u.NON_NULL_TYPE&&e.defaultValue==null}function _r(e){return{Field(t){let n=e.getType(),r=t.selectionSet;if(n)if(J(q(n))){if(r){let i=t.name.value,o=y(n);e.reportError(new f(`Field "${i}" must not have a selection since type "${o}" has no subfields.`,{nodes:r}))}}else if(r){if(r.selections.length===0){let i=t.name.value,o=y(n);e.reportError(new f(`Field "${i}" of type "${o}" must have at least one field selected.`,{nodes:t}))}}else{let i=t.name.value,o=y(n);e.reportError(new f(`Field "${i}" of type "${o}" must have a selection of subfields. Did you mean "${i} { ... }"?`,{nodes:t}))}}}}function pn(e){return e.map(t=>typeof t=="number"?"["+t.toString()+"]":"."+t).join("")}function Pe(e,t,n){return{prev:e,key:t,typename:n}}function W(e){let t=[],n=e;for(;n;)t.push(n.key),n=n.prev;return t.reverse()}function Qi(e,t,n=Os){return Ot(e,t,n,void 0)}function Os(e,t,n){let r="Invalid value "+y(t);throw e.length>0&&(r+=` at "value${pn(e)}"`),n.message=r+": "+n.message,n}function Ot(e,t,n,r){if(b(t)){if(e!=null)return Ot(e,t.ofType,n,r);n(W(r),e,new f(`Expected non-nullable type "${y(t)}" not to be null.`));return}if(e==null)return null;if(w(t)){let i=t.ofType;return Ze(e)?Array.from(e,(o,s)=>{let a=Pe(r,s,void 0);return Ot(o,i,n,a)}):[Ot(e,i,n,r)]}if(L(t)){if(!j(e)){n(W(r),e,new f(`Expected type "${t.name}" to be an object.`));return}let i={},o=t.getFields();for(let s of Object.values(o)){let a=e[s.name];if(a===void 0){if(s.defaultValue!==void 0)i[s.name]=s.defaultValue;else if(b(s.type)){let c=y(s.type);n(W(r),e,new f(`Field "${s.name}" of required type "${c}" was not provided.`))}continue}i[s.name]=Ot(a,s.type,n,Pe(r,s.name,t.name))}for(let s of Object.keys(e))if(!o[s]){let a=ee(s,Object.keys(t.getFields()));n(W(r),e,new f(`Field "${s}" is not defined by type "${t.name}".`+K(a)))}if(t.isOneOf){let s=Object.keys(i);s.length!==1&&n(W(r),e,new f(`Exactly one key must be specified for OneOf type "${t.name}".`));let a=s[0],c=i[a];c===null&&n(W(r).concat(a),c,new f(`Field "${a}" must be non-null.`))}return i}if(J(t)){let i;try{i=t.parseValue(e)}catch(o){o instanceof f?n(W(r),e,o):n(W(r),e,new f(`Expected type "${t.name}". `+o.message,{originalError:o}));return}return i===void 0&&n(W(r),e,new f(`Expected type "${t.name}".`)),i}C(!1,"Unexpected input type: "+y(t))}function Ue(e,t,n){if(e){if(e.kind===u.VARIABLE){let r=e.name.value;if(n==null||n[r]===void 0)return;let i=n[r];return i===null&&b(t)?void 0:i}if(b(t))return e.kind===u.NULL?void 0:Ue(e,t.ofType,n);if(e.kind===u.NULL)return null;if(w(t)){let r=t.ofType;if(e.kind===u.LIST){let o=[];for(let s of e.values)if(Bi(s,n)){if(b(r))return;o.push(null)}else{let a=Ue(s,r,n);if(a===void 0)return;o.push(a)}return o}let i=Ue(e,r,n);return i===void 0?void 0:[i]}if(L(t)){if(e.kind!==u.OBJECT)return;let r=Object.create(null),i=fe(e.fields,o=>o.name.value);for(let o of Object.values(t.getFields())){let s=i[o.name];if(!s||Bi(s.value,n)){if(o.defaultValue!==void 0)r[o.name]=o.defaultValue;else if(b(o.type))return;continue}let a=Ue(s.value,o.type,n);if(a===void 0)return;r[o.name]=a}if(t.isOneOf){let o=Object.keys(r);if(o.length!==1||r[o[0]]===null)return}return r}if(J(t)){let r;try{r=t.parseLiteral(e,n)}catch{return}return r===void 0?void 0:r}C(!1,"Unexpected input type: "+y(t))}}function Bi(e,t){return e.kind===u.VARIABLE&&(t==null||t[e.name.value]===void 0)}function xr(e,t,n,r){let i=[],o=r?.maxErrors;try{let s=Ss(e,t,n,a=>{if(o!=null&&i.length>=o)throw new f("Too many errors processing variables, error limit reached. Execution aborted.");i.push(a)});if(i.length===0)return{coerced:s}}catch(s){i.push(s)}return{errors:i}}function Ss(e,t,n,r){let i={};for(let o of t){let s=o.variable.name.value,a=M(e,o.type);if(!H(a)){let p=x(o.type);r(new f(`Variable "$${s}" expected value of type "${p}" which cannot be used as an input type.`,{nodes:o.type}));continue}if(!qi(n,s)){if(o.defaultValue)i[s]=Ue(o.defaultValue,a);else if(b(a)){let p=y(a);r(new f(`Variable "$${s}" of required type "${p}" was not provided.`,{nodes:o}))}continue}let c=n[s];if(c===null&&b(a)){let p=y(a);r(new f(`Variable "$${s}" of non-null type "${p}" must not be null.`,{nodes:o}));continue}i[s]=Qi(c,a,(p,l,d)=>{let h=`Variable "$${s}" got invalid value `+y(l);p.length>0&&(h+=` at "${s}${pn(p)}"`),r(new f(h+"; "+d.message,{nodes:o,originalError:d}))})}return i}function ln(e,t,n){var r;let i={},o=(r=t.arguments)!==null&&r!==void 0?r:[],s=fe(o,a=>a.name.value);for(let a of e.args){let c=a.name,p=a.type,l=s[c];if(!l){if(a.defaultValue!==void 0)i[c]=a.defaultValue;else if(b(p))throw new f(`Argument "${c}" of required type "${y(p)}" was not provided.`,{nodes:t});continue}let d=l.value,h=d.kind===u.NULL;if(d.kind===u.VARIABLE){let g=d.name.value;if(n==null||!qi(n,g)){if(a.defaultValue!==void 0)i[c]=a.defaultValue;else if(b(p))throw new f(`Argument "${c}" of required type "${y(p)}" was provided the variable "$${g}" which was not provided a runtime value.`,{nodes:d});continue}h=n[g]==null}if(h&&b(p))throw new f(`Argument "${c}" of non-null type "${y(p)}" must not be null.`,{nodes:d});let T=Ue(d,p,n);if(T===void 0)throw new f(`Argument "${c}" has invalid value ${x(d)}.`,{nodes:d});i[c]=T}return i}function fn(e,t,n){var r;let i=(r=t.directives)===null||r===void 0?void 0:r.find(o=>o.name.value===e.name);if(i)return ln(e,i,n)}function qi(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function mn(e,t,n,r,i){let o=new Map;return dn(e,t,n,r,i,o,new Set),o}function Hi(e,t,n,r,i){let o=new Map,s=new Set;for(let a of i)a.selectionSet&&dn(e,t,n,r,a.selectionSet,o,s);return o}function dn(e,t,n,r,i,o,s){for(let a of i.selections)switch(a.kind){case u.FIELD:{if(!Lr(n,a))continue;let c=_s(a),p=o.get(c);p!==void 0?p.push(a):o.set(c,[a]);break}case u.INLINE_FRAGMENT:{if(!Lr(n,a)||!Yi(e,a,r))continue;dn(e,t,n,r,a.selectionSet,o,s);break}case u.FRAGMENT_SPREAD:{let c=a.name.value;if(s.has(c)||!Lr(n,a))continue;s.add(c);let p=t[c];if(!p||!Yi(e,p,r))continue;dn(e,t,n,r,p.selectionSet,o,s);break}}}function Lr(e,t){let n=fn(Xt,t,e);if(n?.if===!0)return!1;let r=fn(zt,t,e);return r?.if!==!1}function Yi(e,t,n){let r=t.typeCondition;if(!r)return!0;let i=M(e,r);return i===n?!0:ne(i)?e.isSubType(i,n):!1}function _s(e){return e.alias?e.alias.value:e.name.value}function wr(e){return{OperationDefinition(t){if(t.operation==="subscription"){let n=e.getSchema(),r=n.getSubscriptionType();if(r){let i=t.name?t.name.value:null,o=Object.create(null),s=e.getDocument(),a=Object.create(null);for(let p of s.definitions)p.kind===u.FRAGMENT_DEFINITION&&(a[p.name.value]=p);let c=mn(n,a,o,r,t.selectionSet);if(c.size>1){let d=[...c.values()].slice(1).flat();e.reportError(new f(i!=null?`Subscription "${i}" must select only one top level field.`:"Anonymous Subscription must select only one top level field.",{nodes:d}))}for(let p of c.values())p[0].name.value.startsWith("__")&&e.reportError(new f(i!=null?`Subscription "${i}" must not select an introspection top level field.`:"Anonymous Subscription must not select an introspection top level field.",{nodes:p}))}}}}}function nt(e,t){let n=new Map;for(let r of e){let i=t(r),o=n.get(i);o===void 0?n.set(i,[r]):o.push(r)}return n}function Dr(e){return{DirectiveDefinition(r){var i;let o=(i=r.arguments)!==null&&i!==void 0?i:[];return n(`@${r.name.value}`,o)},InterfaceTypeDefinition:t,InterfaceTypeExtension:t,ObjectTypeDefinition:t,ObjectTypeExtension:t};function t(r){var i;let o=r.name.value,s=(i=r.fields)!==null&&i!==void 0?i:[];for(let c of s){var a;let p=c.name.value,l=(a=c.arguments)!==null&&a!==void 0?a:[];n(`${o}.${p}`,l)}return!1}function n(r,i){let o=nt(i,s=>s.name.value);for(let[s,a]of o)a.length>1&&e.reportError(new f(`Argument "${r}(${s}:)" can only be defined once.`,{nodes:a.map(c=>c.name)}));return!1}}function hn(e){return{Field:t,Directive:t};function t(n){var r;let i=(r=n.arguments)!==null&&r!==void 0?r:[],o=nt(i,s=>s.name.value);for(let[s,a]of o)a.length>1&&e.reportError(new f(`There can be only one argument named "${s}".`,{nodes:a.map(c=>c.name)}))}}function Ar(e){let t=Object.create(null),n=e.getSchema();return{DirectiveDefinition(r){let i=r.name.value;if(n!=null&&n.getDirective(i)){e.reportError(new f(`Directive "@${i}" already exists in the schema. It cannot be redefined.`,{nodes:r.name}));return}return t[i]?e.reportError(new f(`There can be only one directive named "@${i}".`,{nodes:[t[i],r.name]})):t[i]=r.name,!1}}}function yn(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():Te;for(let a of r)t[a.name]=!a.isRepeatable;let i=e.getDocument().definitions;for(let a of i)a.kind===u.DIRECTIVE_DEFINITION&&(t[a.name.value]=!a.repeatable);let o=Object.create(null),s=Object.create(null);return{enter(a){if(!("directives"in a)||!a.directives)return;let c;if(a.kind===u.SCHEMA_DEFINITION||a.kind===u.SCHEMA_EXTENSION)c=o;else if(Oe(a)||tn(a)){let p=a.name.value;c=s[p],c===void 0&&(s[p]=c=Object.create(null))}else c=Object.create(null);for(let p of a.directives){let l=p.name.value;t[l]&&(c[l]?e.reportError(new f(`The directive "@${l}" can only be used once at this location.`,{nodes:[c[l],p]})):c[l]=p)}}}}function Fr(e){let t=e.getSchema(),n=t?t.getTypeMap():Object.create(null),r=Object.create(null);return{EnumTypeDefinition:i,EnumTypeExtension:i};function i(o){var s;let a=o.name.value;r[a]||(r[a]=Object.create(null));let c=(s=o.values)!==null&&s!==void 0?s:[],p=r[a];for(let l of c){let d=l.name.value,h=n[a];$(h)&&h.getValue(d)?e.reportError(new f(`Enum value "${a}.${d}" already exists in the schema. It cannot also be defined in this type extension.`,{nodes:l.name})):p[d]?e.reportError(new f(`Enum value "${a}.${d}" can only be defined once.`,{nodes:[p[d],l.name]})):p[d]=l.name}return!1}}function kr(e){let t=e.getSchema(),n=t?t.getTypeMap():Object.create(null),r=Object.create(null);return{InputObjectTypeDefinition:i,InputObjectTypeExtension:i,InterfaceTypeDefinition:i,InterfaceTypeExtension:i,ObjectTypeDefinition:i,ObjectTypeExtension:i};function i(o){var s;let a=o.name.value;r[a]||(r[a]=Object.create(null));let c=(s=o.fields)!==null&&s!==void 0?s:[],p=r[a];for(let l of c){let d=l.name.value;xs(n[a],d)?e.reportError(new f(`Field "${a}.${d}" already exists in the schema. It cannot also be defined in this type extension.`,{nodes:l.name})):p[d]?e.reportError(new f(`Field "${a}.${d}" can only be defined once.`,{nodes:[p[d],l.name]})):p[d]=l.name}return!1}}function xs(e,t){return O(e)||_(e)||L(e)?e.getFields()[t]!=null:!1}function Cr(e){let t=Object.create(null);return{OperationDefinition:()=>!1,FragmentDefinition(n){let r=n.name.value;return t[r]?e.reportError(new f(`There can be only one fragment named "${r}".`,{nodes:[t[r],n.name]})):t[r]=n.name,!1}}}function Tn(e){let t=[],n=Object.create(null);return{ObjectValue:{enter(){t.push(n),n=Object.create(null)},leave(){let r=t.pop();r||C(!1),n=r}},ObjectField(r){let i=r.name.value;n[i]?e.reportError(new f(`There can be only one input field named "${i}".`,{nodes:[n[i],r.name]})):n[i]=r.name}}}function Mr(e){let t=Object.create(null);return{OperationDefinition(n){let r=n.name;return r&&(t[r.value]?e.reportError(new f(`There can be only one operation named "${r.value}".`,{nodes:[t[r.value],r]})):t[r.value]=r),!1},FragmentDefinition:()=>!1}}function Pr(e){let t=e.getSchema(),n=Object.create(null),r=t?{query:t.getQueryType(),mutation:t.getMutationType(),subscription:t.getSubscriptionType()}:{};return{SchemaDefinition:i,SchemaExtension:i};function i(o){var s;let a=(s=o.operationTypes)!==null&&s!==void 0?s:[];for(let c of a){let p=c.operation,l=n[p];r[p]?e.reportError(new f(`Type for ${p} already defined in the schema. It cannot be redefined.`,{nodes:c})):l?e.reportError(new f(`There can be only one ${p} type in schema.`,{nodes:[l,c]})):n[p]=c}return!1}}function Ur(e){let t=Object.create(null),n=e.getSchema();return{ScalarTypeDefinition:r,ObjectTypeDefinition:r,InterfaceTypeDefinition:r,UnionTypeDefinition:r,EnumTypeDefinition:r,InputObjectTypeDefinition:r};function r(i){let o=i.name.value;if(n!=null&&n.getType(o)){e.reportError(new f(`Type "${o}" already exists in the schema. It cannot also be defined in this type definition.`,{nodes:i.name}));return}return t[o]?e.reportError(new f(`There can be only one type named "${o}".`,{nodes:[t[o],i.name]})):t[o]=i.name,!1}}function $r(e){return{OperationDefinition(t){var n;let r=(n=t.variableDefinitions)!==null&&n!==void 0?n:[],i=nt(r,o=>o.variable.name.value);for(let[o,s]of i)s.length>1&&e.reportError(new f(`There can be only one variable named "$${o}".`,{nodes:s.map(a=>a.variable.name)}))}}}function Vr(e){let t={};return{OperationDefinition:{enter(){t={}}},VariableDefinition(n){t[n.variable.name.value]=n},ListValue(n){let r=Ke(e.getParentInputType());if(!w(r))return $e(e,n),!1},ObjectValue(n){let r=q(e.getInputType());if(!L(r))return $e(e,n),!1;let i=fe(n.fields,o=>o.name.value);for(let o of Object.values(r.getFields()))if(!i[o.name]&&We(o)){let a=y(o.type);e.reportError(new f(`Field "${r.name}.${o.name}" of required type "${a}" was not provided.`,{nodes:n}))}r.isOneOf&&Ls(e,n,r,i,t)},ObjectField(n){let r=q(e.getParentInputType());if(!e.getInputType()&&L(r)){let o=ee(n.name.value,Object.keys(r.getFields()));e.reportError(new f(`Field "${n.name.value}" is not defined by type "${r.name}".`+K(o),{nodes:n}))}},NullValue(n){let r=e.getInputType();b(r)&&e.reportError(new f(`Expected value of type "${y(r)}", found ${x(n)}.`,{nodes:n}))},EnumValue:n=>$e(e,n),IntValue:n=>$e(e,n),FloatValue:n=>$e(e,n),StringValue:n=>$e(e,n),BooleanValue:n=>$e(e,n)}}function $e(e,t){let n=e.getInputType();if(!n)return;let r=q(n);if(!J(r)){let i=y(n);e.reportError(new f(`Expected value of type "${i}", found ${x(t)}.`,{nodes:t}));return}try{if(r.parseLiteral(t,void 0)===void 0){let o=y(n);e.reportError(new f(`Expected value of type "${o}", found ${x(t)}.`,{nodes:t}))}}catch(i){let o=y(n);i instanceof f?e.reportError(i):e.reportError(new f(`Expected value of type "${o}", found ${x(t)}; `+i.message,{nodes:t,originalError:i}))}}function Ls(e,t,n,r,i){var o;let s=Object.keys(r);if(s.length!==1){e.reportError(new f(`OneOf Input Object "${n.name}" must specify exactly one key.`,{nodes:[t]}));return}let c=(o=r[s[0]])===null||o===void 0?void 0:o.value,p=!c||c.kind===u.NULL,l=c?.kind===u.VARIABLE;if(p){e.reportError(new f(`Field "${n.name}.${s[0]}" must be non-null.`,{nodes:[t]}));return}if(l){let d=c.name.value;i[d].type.kind!==u.NON_NULL_TYPE&&e.reportError(new f(`Variable "${d}" must be non-nullable to be used for OneOf Input Object "${n.name}".`,{nodes:[t]}))}}function Gr(e){return{VariableDefinition(t){let n=M(e.getSchema(),t.type);if(n!==void 0&&!H(n)){let r=t.variable.name.value,i=x(t.type);e.reportError(new f(`Variable "$${r}" cannot be non-input type "${i}".`,{nodes:t.type}))}}}}function jr(e){let t=Object.create(null);return{OperationDefinition:{enter(){t=Object.create(null)},leave(n){let r=e.getRecursiveVariableUsages(n);for(let{node:i,type:o,defaultValue:s}of r){let a=i.name.value,c=t[a];if(c&&o){let p=e.getSchema(),l=M(p,c.type);if(l&&!ws(p,l,c.defaultValue,o,s)){let d=y(l),h=y(o);e.reportError(new f(`Variable "$${a}" of type "${d}" used in position expecting type "${h}".`,{nodes:[c,i]}))}}}}},VariableDefinition(n){t[n.variable.name.value]=n}}}function ws(e,t,n,r,i){if(b(r)&&!b(t)){if(!(n!=null&&n.kind!==u.NULL)&&!(i!==void 0))return!1;let a=r.ofType;return Re(e,t,a)}return Re(e,t,r)}var Qr=Object.freeze([dr]),rt=Object.freeze([or,Mr,lr,wr,rn,ar,Gr,_r,sr,Cr,pr,yr,br,mr,$r,hr,Tr,nn,yn,cr,hn,Vr,Or,jr,Nr,Tn,...Qr]),Ds=Object.freeze([fr,Pr,Ur,Fr,kr,Dr,Ar,rn,nn,yn,Rr,ur,hn,Tn,Sr]);var Br=class{constructor(t,n){this._ast=t,this._fragments=void 0,this._fragmentSpreads=new Map,this._recursivelyReferencedFragments=new Map,this._onError=n}get[Symbol.toStringTag](){return"ASTValidationContext"}reportError(t){this._onError(t)}getDocument(){return this._ast}getFragment(t){let n;if(this._fragments)n=this._fragments;else{n=Object.create(null);for(let r of this.getDocument().definitions)r.kind===u.FRAGMENT_DEFINITION&&(n[r.name.value]=r);this._fragments=n}return n[t]}getFragmentSpreads(t){let n=this._fragmentSpreads.get(t);if(!n){n=[];let r=[t],i;for(;i=r.pop();)for(let o of i.selections)o.kind===u.FRAGMENT_SPREAD?n.push(o):o.selectionSet&&r.push(o.selectionSet);this._fragmentSpreads.set(t,n)}return n}getRecursivelyReferencedFragments(t){let n=this._recursivelyReferencedFragments.get(t);if(!n){n=[];let r=Object.create(null),i=[t.selectionSet],o;for(;o=i.pop();)for(let s of this.getFragmentSpreads(o)){let a=s.name.value;if(r[a]!==!0){r[a]=!0;let c=this.getFragment(a);c&&(n.push(c),i.push(c.selectionSet))}}this._recursivelyReferencedFragments.set(t,n)}return n}};var St=class extends Br{constructor(t,n,r,i){super(n,i),this._schema=t,this._typeInfo=r,this._variableUsages=new Map,this._recursiveVariableUsages=new Map}get[Symbol.toStringTag](){return"ValidationContext"}getSchema(){return this._schema}getVariableUsages(t){let n=this._variableUsages.get(t);if(!n){let r=[],i=new tt(this._schema);Le(t,en(i,{VariableDefinition:()=>!1,Variable(o){r.push({node:o,type:i.getInputType(),defaultValue:i.getDefaultValue()})}})),n=r,this._variableUsages.set(t,n)}return n}getRecursiveVariableUsages(t){let n=this._recursiveVariableUsages.get(t);if(!n){n=this.getVariableUsages(t);for(let r of this.getRecursivelyReferencedFragments(t))n=n.concat(this.getVariableUsages(r));this._recursiveVariableUsages.set(t,n)}return n}getType(){return this._typeInfo.getType()}getParentType(){return this._typeInfo.getParentType()}getInputType(){return this._typeInfo.getInputType()}getParentInputType(){return this._typeInfo.getParentInputType()}getFieldDef(){return this._typeInfo.getFieldDef()}getDirective(){return this._typeInfo.getDirective()}getArgument(){return this._typeInfo.getArgument()}getEnumValue(){return this._typeInfo.getEnumValue()}};function gn(e,t,n=rt,r,i=new tt(e)){var o;let s=(o=r?.maxErrors)!==null&&o!==void 0?o:100;t||R(!1,"Must provide document."),Rt(e);let a=Object.freeze({}),c=[],p=new St(e,t,i,d=>{if(c.length>=s)throw c.push(new f("Too many validation errors, error limit reached. Validation aborted.")),a;c.push(d)}),l=Vn(n.map(d=>d(p)));try{Le(t,en(i,l))}catch(d){if(d!==a)throw d}return c}function Ji(e){let t;return function(r,i,o){t===void 0&&(t=new WeakMap);let s=t.get(r);s===void 0&&(s=new WeakMap,t.set(r,s));let a=s.get(i);a===void 0&&(a=new WeakMap,s.set(i,a));let c=a.get(o);return c===void 0&&(c=e(r,i,o),a.set(o,c)),c}}function qr(e){return Promise.all(Object.values(e)).then(t=>{let n=Object.create(null);for(let[r,i]of Object.keys(e).entries())n[i]=t[r];return n})}function zi(e,t,n){let r=n;for(let i of e)r=se(r)?r.then(o=>t(o,i)):t(r,i);return r}function Xi(e){return e instanceof Error?e:new Yr(e)}var Yr=class extends Error{constructor(t){super("Unexpected error value: "+y(t)),this.name="NonErrorThrown",this.thrownValue=t}};function _t(e,t,n){var r;let i=Xi(e);return As(i)?i:new f(i.message,{nodes:(r=i.nodes)!==null&&r!==void 0?r:t,source:i.source,positions:i.positions,path:n,originalError:i})}function As(e){return Array.isArray(e.path)}var Fs=Ji((e,t,n)=>Hi(e.schema,e.fragments,e.variableValues,t,n));function bn(e){arguments.length<2||R(!1,"graphql@16 dropped long-deprecated support for positional arguments, please pass an object instead.");let{schema:t,document:n,variableValues:r,rootValue:i}=e;ks(t,n,r);let o=Cs(e);if(!("schema"in o))return{errors:o};try{let{operation:s}=o,a=Ms(o,s,i);return se(a)?a.then(c=>En(c,o.errors),c=>(o.errors.push(c),En(null,o.errors))):En(a,o.errors)}catch(s){return o.errors.push(s),En(null,o.errors)}}function En(e,t){return t.length===0?{data:e}:{errors:t,data:e}}function ks(e,t,n){t||R(!1,"Must provide document."),Rt(e),n==null||j(n)||R(!1,"Variables must be provided as an Object where each property is a variable value. Perhaps look to see if an unparsed JSON string was provided.")}function Cs(e){var t,n;let{schema:r,document:i,rootValue:o,contextValue:s,variableValues:a,operationName:c,fieldResolver:p,typeResolver:l,subscribeFieldResolver:d}=e,h,T=Object.create(null);for(let k of i.definitions)switch(k.kind){case u.OPERATION_DEFINITION:if(c==null){if(h!==void 0)return[new f("Must provide operation name if query contains multiple operations.")];h=k}else((t=k.name)===null||t===void 0?void 0:t.value)===c&&(h=k);break;case u.FRAGMENT_DEFINITION:T[k.name.value]=k;break;default:}if(!h)return c!=null?[new f(`Unknown operation named "${c}".`)]:[new f("Must provide an operation.")];let g=(n=h.variableDefinitions)!==null&&n!==void 0?n:[],D=xr(r,g,a??{},{maxErrors:50});return D.errors?D.errors:{schema:r,fragments:T,rootValue:o,contextValue:s,operation:h,variableValues:D.coerced,fieldResolver:p??In,typeResolver:l??Jr,subscribeFieldResolver:d??In,errors:[]}}function Ms(e,t,n){let r=e.schema.getRootType(t.operation);if(r==null)throw new f(`Schema is not configured to execute ${t.operation} operation.`,{nodes:t});let i=mn(e.schema,e.fragments,e.variableValues,r,t.selectionSet),o=void 0;switch(t.operation){case F.QUERY:return vn(e,r,n,o,i);case F.MUTATION:return Ps(e,r,n,o,i);case F.SUBSCRIPTION:return vn(e,r,n,o,i)}}function Ps(e,t,n,r,i){return zi(i.entries(),(o,[s,a])=>{let c=Pe(r,s,t.name),p=Zi(e,t,n,a,c);return p===void 0?o:se(p)?p.then(l=>(o[s]=l,o)):(o[s]=p,o)},Object.create(null))}function vn(e,t,n,r,i){let o=Object.create(null),s=!1;try{for(let[a,c]of i.entries()){let p=Pe(r,a,t.name),l=Zi(e,t,n,c,p);l!==void 0&&(o[a]=l,se(l)&&(s=!0))}}catch(a){if(s)return qr(o).finally(()=>{throw a});throw a}return s?qr(o):o}function Zi(e,t,n,r,i){var o;let s=js(e.schema,t,r[0]);if(!s)return;let a=s.type,c=(o=s.resolve)!==null&&o!==void 0?o:e.fieldResolver,p=Us(e,s,r,t,i);try{let l=ln(s,r[0],e.variableValues),d=e.contextValue,h=c(n,l,d,p),T;return se(h)?T=h.then(g=>xt(e,a,r,p,i,g)):T=xt(e,a,r,p,i,h),se(T)?T.then(void 0,g=>{let D=_t(g,r,W(i));return Nn(D,a,e)}):T}catch(l){let d=_t(l,r,W(i));return Nn(d,a,e)}}function Us(e,t,n,r,i){return{fieldName:t.name,fieldNodes:n,returnType:t.type,parentType:r,path:i,schema:e.schema,fragments:e.fragments,rootValue:e.rootValue,operation:e.operation,variableValues:e.variableValues}}function Nn(e,t,n){if(b(t))throw e;return n.errors.push(e),null}function xt(e,t,n,r,i,o){if(o instanceof Error)throw o;if(b(t)){let s=xt(e,t.ofType,n,r,i,o);if(s===null)throw new Error(`Cannot return null for non-nullable field ${r.parentType.name}.${r.fieldName}.`);return s}if(o==null)return null;if(w(t))return $s(e,t,n,r,i,o);if(J(t))return Vs(t,o);if(ne(t))return Gs(e,t,n,r,i,o);if(O(t))return Hr(e,t,n,r,i,o);C(!1,"Cannot complete value of unexpected output type: "+y(t))}function $s(e,t,n,r,i,o){if(!Ze(o))throw new f(`Expected Iterable, but did not find one for field "${r.parentType.name}.${r.fieldName}".`);let s=t.ofType,a=!1,c=Array.from(o,(p,l)=>{let d=Pe(i,l,void 0);try{let h;return se(p)?h=p.then(T=>xt(e,s,n,r,d,T)):h=xt(e,s,n,r,d,p),se(h)?(a=!0,h.then(void 0,T=>{let g=_t(T,n,W(d));return Nn(g,s,e)})):h}catch(h){let T=_t(h,n,W(d));return Nn(T,s,e)}});return a?Promise.all(c):c}function Vs(e,t){let n=e.serialize(t);if(n==null)throw new Error(`Expected \`${y(e)}.serialize(${y(t)})\` to return non-nullable value, returned: ${y(n)}`);return n}function Gs(e,t,n,r,i,o){var s;let a=(s=t.resolveType)!==null&&s!==void 0?s:e.typeResolver,c=e.contextValue,p=a(o,c,r,t);return se(p)?p.then(l=>Hr(e,Ki(l,e,t,n,r,o),n,r,i,o)):Hr(e,Ki(p,e,t,n,r,o),n,r,i,o)}function Ki(e,t,n,r,i,o){if(e==null)throw new f(`Abstract type "${n.name}" must resolve to an Object type at runtime for field "${i.parentType.name}.${i.fieldName}". Either the "${n.name}" type should provide a "resolveType" function or each possible type should provide an "isTypeOf" function.`,r);if(O(e))throw new f("Support for returning GraphQLObjectType from resolveType was removed in graphql-js@16.0.0 please return type name instead.");if(typeof e!="string")throw new f(`Abstract type "${n.name}" must resolve to an Object type at runtime for field "${i.parentType.name}.${i.fieldName}" with value ${y(o)}, received "${y(e)}".`);let s=t.schema.getType(e);if(s==null)throw new f(`Abstract type "${n.name}" was resolved to a type "${e}" that does not exist inside the schema.`,{nodes:r});if(!O(s))throw new f(`Abstract type "${n.name}" was resolved to a non-object type "${e}".`,{nodes:r});if(!t.schema.isSubType(n,s))throw new f(`Runtime Object type "${s.name}" is not a possible type for "${n.name}".`,{nodes:r});return s}function Hr(e,t,n,r,i,o){let s=Fs(e,t,n);if(t.isTypeOf){let a=t.isTypeOf(o,e.contextValue,r);if(se(a))return a.then(c=>{if(!c)throw Wi(t,o,n);return vn(e,t,o,i,s)});if(!a)throw Wi(t,o,n)}return vn(e,t,o,i,s)}function Wi(e,t,n){return new f(`Expected value of type "${e.name}" but got: ${y(t)}.`,{nodes:n})}var Jr=function(e,t,n,r){if(j(e)&&typeof e.__typename=="string")return e.__typename;let i=n.schema.getPossibleTypes(r),o=[];for(let s=0;s<i.length;s++){let a=i[s];if(a.isTypeOf){let c=a.isTypeOf(e,t,n);if(se(c))o[s]=c;else if(c)return a.name}}if(o.length)return Promise.all(o).then(s=>{for(let a=0;a<s.length;a++)if(s[a])return i[a].name})},In=function(e,t,n,r){if(j(e)||typeof e=="function"){let i=e[r.fieldName];return typeof i=="function"?e[r.fieldName](t,n,r):i}};function js(e,t,n){let r=n.name.value;return r===Ae.name&&e.getQueryType()===t?Ae:r===Fe.name&&e.getQueryType()===t?Fe:r===ke.name?ke:t.getFields()[r]}import{OperationOutcomeError as z,Operator as la,allOk as eo,badRequest as Se,created as to,deepClone as it,evalFhirPath as no,generateId as ro,globalSchema as fa,matchesSearchRequest as da,multipleMatches as zr,normalizeOperationOutcome as ma,notFound as Rn,preconditionFailed as ha,stringify as ya}from"@medplum/core";import{applyPatch as Ta}from"rfc6902";var On={READER:"reader",WRITER:"writer"},Xr=class{async searchOne(t){return(await this.search({...t,count:1})).entry?.[0]?.resource}async searchResources(t){return(await this.search(t)).entry?.map(r=>r.resource)??[]}async conditionalCreate(t,n,r){if(n.resourceType!==t.resourceType)throw new z(Se("Search type must match resource type for conditional update"));return n.count=2,n.sortRules=void 0,this.withTransaction(async()=>{let i=await this.searchResources(n);if(i.length===1){let s=i[0];if(!r?.assignedId&&t.id&&t.id!==s.id)throw new z(Se("Resource ID did not match resolved ID",t.resourceType+".id"));return{resource:i[0],outcome:eo}}else if(i.length>1)throw new z(zr);return{resource:await this.createResource(t,r),outcome:to}},{serializable:!0})}async conditionalUpdate(t,n,r){if(n.resourceType!==t.resourceType)throw new z(Se("Search type must match resource type for conditional update"));return n.count=2,n.sortRules=void 0,this.withTransaction(async()=>{let i=await this.searchResources(n);if(i.length===0){if(t.id&&!r?.assignedId)throw new z(Se("Cannot perform create as update with client-assigned ID",t.resourceType+".id"));return{resource:await this.createResource(t,r),outcome:to}}else if(i.length>1)throw new z(zr);let o=i[0];if(t.id&&t.id!==o.id)throw new z(Se("Resource ID did not match resolved ID",t.resourceType+".id"));return{resource:await this.updateResource({...t,id:o.id},r),outcome:eo}},{serializable:!0})}async conditionalDelete(t){t.count=2,t.sortRules=void 0,await this.withTransaction(async()=>{let n=await this.searchResources(t);if(n.length>1)throw new z(zr);if(!n.length)return;let r=n[0];await this.deleteResource(r.resourceType,r.id)})}},io=class extends Xr{constructor(){super(),this.resources=new Map,this.history=new Map}clear(){this.resources.clear(),this.history.clear()}setMode(t){}async createResource(t){let n=JSON.parse(ya(t));n.id||(n.id=this.generateId()),n.meta||(n.meta={}),n.meta.versionId||(n.meta.versionId=ro()),n.meta.lastUpdated||(n.meta.lastUpdated=new Date().toISOString());let{resourceType:r,id:i}=n,o=this.resources.get(r);o||(o=new Map,this.resources.set(r,o)),o.set(i,n);let s=this.history.get(r);s||(s=new Map,this.history.set(r,s));let a=s.get(i);return a||(a=[],s.set(i,a)),a.push(n),it(n)}generateId(){return ro()}updateResource(t,n){if(!t.id)throw new z(Se("Missing id"));if(n?.ifMatch){let i=n.ifMatch,o=this.resources.get(t.resourceType)?.get(t.id);if(!o)throw new z(Rn);if(o.meta?.versionId!==i)throw new z(ha)}let r=it(t);return r.meta&&(r.meta.versionId&&delete r.meta.versionId,r.meta.lastUpdated&&delete r.meta.lastUpdated),this.createResource(r)}async patchResource(t,n,r){let i=await this.readResource(t,n);try{let o=Ta(i,r).filter(Boolean);if(o.length>0)throw new z(Se(o.map(s=>s.message).join(`
54
54
  `)))}catch(o){throw new z(ma(o))}return this.updateResource(i)}async readResource(t,n){let r=this.resources.get(t)?.get(n);if(!r)throw new z(Rn);return it(r)}async readReference(t){let n=t.reference?.split("/");if(!n||n.length!==2)throw new z(Se("Invalid reference"));return this.readResource(n[0],n[1])}async readReferences(t){return Promise.all(t.map(n=>this.readReference(n)))}async readHistory(t,n){await this.readResource(t,n);let r=(this.history.get(t)?.get(n)??[]).reverse().map(i=>({resource:it(i)}));return{resourceType:"Bundle",type:"history",...r.length?{entry:r}:void 0}}async readVersion(t,n,r){await this.readResource(t,n);let i=this.history.get(t)?.get(n)?.find(o=>o.meta?.versionId===r);if(!i)throw new z(Rn);return it(i)}async search(t){let{resourceType:n}=t,r=this.resources.get(n)??new Map,i=[];for(let s of r.values())da(s,t)&&i.push(s);let o=i.map(s=>({resource:it(s)}));if(t.sortRules)for(let s of t.sortRules)o=o.sort((a,c)=>ga(a.resource,c.resource,s));return t.offset!==void 0&&(o=o.slice(t.offset)),t.count!==void 0&&(o=o.slice(0,t.count)),{resourceType:"Bundle",type:"searchset",entry:o.length?o:void 0,total:i.length}}async searchByReference(t,n,r){t.filters??=[];let i={};for(let o of r){t.filters.push({code:n,operator:la.EQUALS,value:o});let s=await this.search(t);i[o]=[];for(let a of s.entry??[])a.resource&&i[o].push(a.resource);t.filters.pop()}return i}async deleteResource(t,n){if(!this.resources.get(t)?.get(n))throw new z(Rn);this.resources.get(t)?.delete(n)}withTransaction(t){return console.debug("WARN: MockRepository does not support transactions"),t(void 0)}},ga=(e,t,n)=>{let i=fa.types[e.resourceType]?.searchParams?.[n.code]?.expression;if(!i)return 0;let o=JSON.stringify(no(i,e)),s=JSON.stringify(no(i,t));return o.localeCompare(s)*(n.descending?-1:1)};import{capitalize as La,getDataType as po,isResourceType as wa}from"@medplum/core";import{DEFAULT_MAX_SEARCH_COUNT as Ea,DEFAULT_SEARCH_COUNT as va,getReferenceString as Na,getSearchParameters as Ia,Operator as ba,parseSearchRequest as Ra}from"@medplum/core";import Oa from"dataloader";var Sn={base64Binary:v,boolean:V,canonical:v,code:v,date:v,dateTime:v,decimal:ue,id:ye,instant:v,integer:ue,markdown:v,number:ue,oid:v,positiveInt:ue,string:v,time:v,unsignedInt:ue,uri:v,url:v,uuid:v,xhtml:v,"http://hl7.org/fhirpath/System.Boolean":V,"http://hl7.org/fhirpath/System.Date":v,"http://hl7.org/fhirpath/System.DateTime":v,"http://hl7.org/fhirpath/System.Decimal":ue,"http://hl7.org/fhirpath/System.Integer":ue,"http://hl7.org/fhirpath/System.String":v,"http://hl7.org/fhirpath/System.Time":v};function oo(e,t,n){let r;if(t){let o=n._reference;delete n._reference,r={code:o,operator:ba.EQUALS,value:Na(t)}}return n=Object.fromEntries(Object.entries(n).map(([o,s])=>[Sa(o),s])),{searchRequest:Ra(e,n),referenceFilter:r}}function so(e,t){let n=e.filters||[];e.filters=[t,...n]}function ao(e,t,n){let{searchRequest:r,referenceFilter:i}=oo(e,t,n);return i&&so(r,i),r}function Kr(e,t){e.count=Math.min(e.count??va,t??Ea)}function Sa(e){return e.startsWith("_")?e:e.replaceAll("_","-")}function Wr(e){return e.replaceAll("-","_")}function _a(e){return JSON.stringify(e,(n,r)=>r&&typeof r=="object"&&!Array.isArray(r)?Object.keys(r).sort((i,o)=>i.localeCompare(o)).reduce((i,o)=>(i[o]=r[o],i),{}):r)}async function _n(e,t,n,r){if(n.searchCount++,n.config?.graphqlMaxSearches&&n.searchCount>n.config.graphqlMaxSearches)throw new Error("Maximum number of searches exceeded");let i=r.fieldName,o=i.substring(0,i.length-4),{searchRequest:s,referenceFilter:a}=oo(o,e,t);Kr(s,n.config?.graphqlMaxSearches);let c=n.config?.graphqlBatchedSearchSize??0;if(c===0||!a)return a&&so(s,a),(await n.repo.search(s)).entry?.map(h=>h.resource);let p=_a(s);return(n.searchDataLoaders[p]??=xa(n.repo,s,c)).load(a)}function xa(e,t,n){return new Oa(async r=>{let i=await e.searchByReference(t,r[0].code,r.map(o=>o.value));return r.map(o=>i[o.value])},{maxBatchSize:n})}function Lt(e){let t={_count:{type:ce,description:"Specify how many elements to return from a repeating list."},_offset:{type:ce,description:"Specify the offset to start at for a repeating element."},_sort:{type:v,description:"Specify the sort order by comma-separated list of sort rules in priority order."},_id:{type:v,description:"Select resources based on the logical id of the resource."},_lastUpdated:{type:v,description:"Select resources based on the last time they were changed."},_filter:{type:v,description:" The _filter parameter provides a syntax for expressing a set of query expressions on the underlying resources."}},n=Ia(e);if(n)for(let[r,i]of Object.entries(n))t[Wr(r)]={type:v,description:i.description};return t}function Zr(e,t){return e.fieldNodes.some(n=>n.selectionSet?.selections.some(r=>r.kind===u.FIELD&&r.name.value===t))}function co(e){return{resourceType:"OperationOutcome",issue:e.map(t=>({severity:"error",code:"invalid",details:{text:t.message}}))}}var uo={...Sn};function wt(e,t){let n=uo[e];return n||(n=Da(e,t),uo[e]=n),n}function Da(e,t){let n=po(e);return new De({name:e+t,description:n.description,fields:()=>Aa(e,t)})}function Aa(e,t){let n={};if(wa(e)){let r={description:"The type of resource",type:v};n.resourceType=r}return Fa(e,n,t),n}function Fa(e,t,n){let r=po(e);for(let[i,o]of Object.entries(r.elements))for(let s of o.type)ka(t,i,o,s,n)}function ka(e,t,n,r,i){let o=r.code;if(o==="Resource")return;(o==="Element"||o==="BackboneElement")&&(o=n.type[0].code);let s={description:n.description,type:wt(o,i)};n.max>1&&(s.type=new A(new I(wt(o,i)))),n.min>0&&!t.endsWith("[x]")&&(s.type=new I(s.type));let a=t.split(".").pop().replace("[x]",La(r.code));e[a]=s}import{capitalize as lo,evalFhirPathTyped as Ca,getDataType as fo,getResourceTypes as mo,getSearchParameters as Ma,isLowerCase as Pa,isReference as Ua,isResourceTypeSchema as $a,normalizeOperationOutcome as Va,OperationOutcomeError as Ga,toJsBoolean as ja,toTypedValue as Qa,tryGetDataType as Ba}from"@medplum/core";var xn={...Sn};function Ve(e){let t=xn[e];return t||(t=ei(e),xn[e]=t),t}function ei(e){if(e==="ResourceList")return new we({name:"ResourceList",types:()=>mo().map(Ve).filter(n=>!!n),resolveType:ec});let t=fo(e);return new Q({name:e,description:t.description,fields:()=>qa(e)})}function qa(e){let t={};return Ya(e,t),Xa(e,t),t}function Ya(e,t){let n=fo(e);$a(n)&&(t.resourceType={type:new I(v),description:"Resource Type"}),e==="Reference"&&(t.resource={description:"Reference",type:Ve("ResourceList"),resolve:Za});for(let[r,i]of Object.entries(n.elements))for(let o of i.type)Ha(t,r,i,o)}function Ha(e,t,n,r){let i=r.code;(i==="Element"||i==="BackboneElement")&&(i=n.type[0].code),i==="Resource"&&(i="ResourceList");let o={description:n.description,type:Ka(n,i,t),resolve:Wa};n.max>1&&(o.args=Ja(i));let s=t.split(".").pop().replace("[x]",lo(r.code));e[s]=o}function Ja(e){let t={_count:{type:ce,description:"Specify how many elements to return from a repeating list."},_offset:{type:ce,description:"Specify the offset to start at for a repeating element."}};if(!Pa(e.charAt(0))){t.fhirpath={type:v,description:"A FHIRPath statement selecting which of the subnodes is to be included"};let n=Ba(e);if(n?.elements)for(let[r,i]of Object.entries(n.elements))for(let o of i.type)za(t,r,i,o)}return t}function za(e,t,n,r){let i=r.code,o=t.replace("[x]",lo(i));switch(i){case"canonical":case"code":case"id":case"oid":case"string":case"uri":case"url":case"uuid":case"http://hl7.org/fhirpath/System.String":e[o]={type:v,description:n.description};break}}function Xa(e,t){for(let n of mo()){let r=Ve(n),i=Ma(n),o={},s=0;if(i)for(let[a,c]of Object.entries(i))c.target?.includes(e)&&(o[Wr(a)]={value:a},s++);if(s>0){let a=new ve({name:e+"_"+n+"_reference",values:o}),c=Lt(n);c._reference={type:new I(a),description:`Specify which property to use for reverse lookup for ${n}`},t[n+"List"]={type:new A(r),args:c,resolve:_n}}}}function Ka(e,t,n){let r=Ve(t);return e.max>1&&(r=new A(new I(r))),e.min!==0&&!n.endsWith("[x]")&&(r=new I(r)),r}async function Wa(e,t,n,r){let i=e?.[r.fieldName];if(!t||!i)return i;let{_offset:o,_count:s,fhirpath:a,...c}=t,p=i;for(let[l,d]of Object.entries(c))p=p.filter(h=>h[l]===d);return a&&(p=p.filter(l=>ja(Ca(a,[Qa(l)])))),o&&(p=p.slice(o)),s&&(p=p.slice(0,s)),p}async function Za(e,t,n){if(Ua(e))try{return await n.dataLoader.load(e)}catch(r){throw new Ga(Va(r),r)}}function ec(e){let t=e?.resourceType;if(t)return Ve(t).name}var cc=new oc,ti;async function To(e,t,n,r){let{query:i,operationName:o,variables:s}=e.body;if(!i)return[Dt("Must provide query.")];let a;try{a=$t(i)}catch{return[Dt("GraphQL syntax error.")]}let c=lc(),p=[...rt,Ic(n,e.config?.graphqlMaxDepth),Rc(n)],l=gn(c,a,p);if(l.length>0)return[co(l)];let d=uc(i);if(d&&!n.options?.introspectionEnabled)return[ic];!r?.batch&&!pc(i)&&t.setMode(On.READER);let h=new ac(g=>t.readReferences(g)),T=d&&cc.get(i);if(!T){let g={repo:t,config:e.config,dataLoader:h,searchCount:0,searchDataLoaders:Object.create(null)};T=await bn({schema:c,document:a,contextValue:g,operationName:o,variableValues:s})}return[tc,T,{contentType:nc.JSON}]}function uc(e){return e.includes("query IntrospectionQuery")||e.includes("__schema")}function pc(e){return e.includes("mutation")}function lc(){return ti||(ti=fc()),ti}function fc(){for(let n of ho())xn[n]=ei(n);let e={},t={};for(let n of ho()){let r=Ve(n);e[n]={type:r,args:{id:{type:new I(ye),description:n+" ID"}},resolve:Tc},e[n+"List"]={type:new A(r),args:Lt(n),resolve:_n},e[n+"Connection"]={type:hc(n,r),args:Lt(n),resolve:yc},t[n+"Create"]={type:r,args:dc(n),resolve:gc},t[n+"Update"]={type:r,args:mc(n),resolve:Ec},t[n+"Delete"]={type:r,args:{id:{type:new I(ye),description:n+" ID"}},resolve:vc}}return new Ce({query:new Q({name:"QueryType",fields:e}),mutation:new Q({name:"MutationType",fields:t})})}function dc(e){return{res:{type:new I(wt(e,"Create")),description:e+" Create"}}}function mc(e){return{id:{type:new I(ye),description:e+" ID"},res:{type:new I(wt(e,"Update")),description:e+" Update"}}}function hc(e,t){return new Q({name:e+"Connection",fields:{count:{type:ce},offset:{type:ce},pageSize:{type:ce},first:{type:v},previous:{type:v},next:{type:v},last:{type:v},edges:{type:new A(new Q({name:e+"ConnectionEdge",fields:{mode:{type:v},score:{type:ue},resource:{type:t}}}))}}})}async function yc(e,t,n,r){let i=r.fieldName,o=i.substring(0,i.length-10),s=ao(o,e,t);Zr(r,"count")&&(s.total="accurate"),Zr(r,"edges")||(s.count=0),Kr(s,n.config?.graphqlMaxSearches);let a=await n.repo.search(s);return{count:a.total,offset:s.offset??0,pageSize:s.count??rc,edges:a.entry?.map(c=>({mode:c.search?.mode,score:c.search?.score,resource:c.resource}))}}async function Tc(e,t,n,r){try{return await n.dataLoader.load({reference:`${r.fieldName}/${t.id}`})}catch(i){throw new Ln(sc(i),i)}}async function gc(e,t,n,r){let i=r.fieldName,o=i.substring(0,i.length-6),s=t.res;if(s.resourceType!==o)throw new Ln(Dt("Invalid resourceType"));return n.repo.createResource(yo(s))}async function Ec(e,t,n,r){let i=r.fieldName,o=i.substring(0,i.length-6),s=t.res,a=t.id;if(s.resourceType!==o)throw new Ln(Dt("Invalid resourceType"));if(a!==s.id)throw new Ln(Dt("Invalid ID"));return n.repo.updateResource(yo(s))}async function vc(e,t,n,r){let i=r.fieldName,o=i.substring(0,i.length-6);await n.repo.deleteResource(o,t.id)}var Nc=12,Ic=(e,t=Nc)=>n=>new ni(n,e,t),ni=class{constructor(t,n,r){this.context=t,this.router=n,this.fragmentDepths=Object.create(null),this.maxDepth=r}OperationDefinition(t){let n=this.getDepth(...t.selectionSet.selections);n.depth>this.maxDepth&&this.router.log("warn","Query max depth too high",{depth:n.depth,limit:this.maxDepth,query:t.loc?.source?.body})}getDepth(...t){let n={depth:-1};for(let r of t){let i={depth:0};if(r.kind===u.FIELD)r.selectionSet?.selections?(i=this.getDepth(...r.selectionSet.selections),i.depth+=1):i={depth:0,node:r};else if(r.kind===u.FRAGMENT_SPREAD){let o=r.name.value,s=this.context.getFragment(o),a=this.fragmentDepths[o];a?i=a:s&&(i=this.getDepth(...s.selectionSet.selections),this.fragmentDepths[o]=i)}else r.kind===u.INLINE_FRAGMENT&&(i=this.getDepth(...r.selectionSet.selections));if(i.depth>this.maxDepth)return i;i.depth>n.depth&&(n=i)}return n}},bc=1e4,Rc=(e,t)=>n=>new ri(n,e,t),ri=class{constructor(t,n,r){this.context=t,this.maxCost=r?.maxCost??bc,this.debug=r?.debug??!1,this.router=n,this.fragmentCosts=Object.create(null)}OperationDefinition(t){let n=0;for(let r of t.selectionSet.selections){let i=performance.now(),o=this.calculateCost(r);n+=o,this.log(r.kind,"node has final cost",o,"(",performance.now()-i,"ms)"),n>this.maxCost&&this.router.log("warn","GraphQL query too complex",{cost:n,limit:this.maxCost,query:t.loc?.source?.body})}}calculateCost(...t){let n=0;for(let r of t){if(r.kind===u.FIELD&&r.selectionSet){let i=0,o=1;Oc(r)?(this.log("Found search field",r.name.value),i=8,o=this.getCount(r.arguments)??20):Sc(r)&&(this.log("Found linked resource"),i=1,o=2);let s=i+o*this.calculateCost(...r.selectionSet.selections);s&&this.log("Field",r.name.value,"costs",s),n+=s}else if(r.kind===u.FRAGMENT_SPREAD){let i=r.name.value,o=this.context.getFragment(i),s=this.fragmentCosts[i];if(s!==void 0)this.log("Fragment",i,"costs",s,"(cached)"),n+=s;else if(o){let a=this.calculateCost(...o.selectionSet.selections);this.fragmentCosts[i]=a,this.log("Fragment",i,"costs",a),n+=a}}else if(r.kind===u.INLINE_FRAGMENT){let i=this.calculateCost(...r.selectionSet.selections);this.log("Inline fragment on",r.typeCondition?.name.value,"costs",i),n+=i}if(n>this.maxCost)return n}return n}getCount(t){let n=t?.find(r=>r.name.value==="_count");if(n?.value.kind===u.INT)return parseInt(n.value.value,10)}log(...t){this.debug&&console.log(...t)}};function Oc(e){return e.name.value.endsWith("List")}function Sc(e){return e.name.value==="resource"}var wn=class{constructor(){this.routes=[]}add(t,n,r,i){let o=n.split("/").filter(s=>!!s).map(s=>s.startsWith(":")?{value:s.substring(1),param:!0}:{value:s});this.routes.push({method:t,path:o,handler:r,data:i})}find(t,n){let r=n.indexOf("?"),i=r>-1,o=n.substring(0,i?r:n.length).split("/").filter(Boolean),s,a=-1;for(let c of this.routes){let p=_c(c,t,o);p>a&&(s=c,a=p)}if(s)return{handler:s.handler,path:o.join("/"),params:xc(s,o),query:i?Lc(n):void 0,data:s.data}}};function _c(e,t,n){if(t!==e.method||n.length!==e.path.length)return-1;let r=0;for(let i=0;i<n.length;i++)if(!e.path[i].param){if(n[i]!==e.path[i].value)return-1;r++}return r}function xc(e,t){let n=Object.create(null);for(let r=0;r<t.length;r++)e.path[r].param&&(n[e.path[r].value]=t[r]);return n}function Lc(e){let t=new URL(e,"https://example.com/"),n=Object.create(null),r=t.searchParams;for(let i of r.keys()){let o=r.getAll(i);n[i]=o.length===1?o[0]:o}return n}async function Mc(e,t,n){let r=e.body;if(r.resourceType!=="Bundle")return[_e("Not a bundle")];let i=await li(e,t,n,r);return[Ee,i]}async function Pc(e,t,n,r){ii(e,t,r);let{resourceType:i}=e.params,o=await t.search(ot(i,e.query));return[Ee,o]}async function Uc(e,t,n,r){ii(e,t,r);let i=ot("MultipleTypes",e.query);if(!i.types||i.types.length===0)return[_e("No types specified")];let o=await t.search(i);return[Ee,o]}async function $c(e,t,n,r){ii(e,t,r);let{resourceType:i}=e.params,o=e.body,s=await t.search(ot(i,o));return[Ee,s]}function ii(e,t,n){!n?.batch&&e.config?.searchOnReader&&t.setMode(On.READER)}async function Vc(e,t,n,r){let{resourceType:i}=e.params,o=e.body,s=!!r?.batch;if(e.query?._account&&typeof e.query._account=="string"&&(o.meta=o.meta||{},o.meta.account={reference:e.query._account}),e.headers?.["if-none-exist"]){let a=Cc(e.headers["if-none-exist"]),c=await t.conditionalCreate(o,ot(`${i}?${a}`),{assignedId:s});return[c.outcome,c.resource]}return Gc(i,o,t,{assignedId:s})}async function Gc(e,t,n,r){if(t.resourceType!==e)return[_e(`Incorrect resource type: expected ${e}, but found ${t.resourceType||"<EMPTY>"}`)];let i=await n.createResource(t,r);return[Ac,i]}async function jc(e,t){let{resourceType:n,id:r}=e.params,i=await t.readResource(n,r);return[Ee,i]}async function Qc(e,t){let{resourceType:n,id:r}=e.params,i=await t.readHistory(n,r);return[Ee,i]}async function Bc(e,t){let{resourceType:n,id:r,vid:i}=e.params,o=await t.readVersion(n,r,i);return[Ee,o]}async function qc(e,t){let{resourceType:n,id:r}=e.params,i=e.body;return Yc(n,r,i,t,{ifMatch:Kc(e.headers?.["if-match"])})}async function Yc(e,t,n,r,i){if(n.resourceType!==e)return[_e("Incorrect resource type")];if(n.id!==t)return[_e("Incorrect resource ID")];let o=await r.updateResource(n,i);return[Ee,o]}async function Hc(e,t,n,r){let{resourceType:i}=e.params,o=e.body,s=ot(i,e.query),a=await t.conditionalUpdate(o,s,{assignedId:r?.batch});return[a.outcome,a.resource]}async function Jc(e,t){let{resourceType:n,id:r}=e.params;return await t.deleteResource(n,r),[Ee]}async function zc(e,t){let{resourceType:n}=e.params,r=ot(n,e.query);return await t.conditionalDelete(r),[Ee]}async function Xc(e,t){let{resourceType:n,id:r}=e.params,i=e.body;if(!i)return[_e("Empty patch body")];if(!Array.isArray(i))return[_e("Patch body must be an array")];let o=await t.patchResource(n,r,i);return[Ee,o]}var go=class extends wc{constructor(n={}){super();this.router=new wn;this.options=n,this.router.add("GET","",Uc,{interaction:"search-system"}),this.router.add("POST","",Mc,{interaction:"batch"}),this.router.add("GET",":resourceType",Pc,{interaction:"search-type"}),this.router.add("POST",":resourceType/_search",$c,{interaction:"search-type"}),this.router.add("POST",":resourceType",Vc,{interaction:"create"}),this.router.add("GET",":resourceType/:id",jc,{interaction:"read"}),this.router.add("GET",":resourceType/:id/_history",Qc,{interaction:"history-instance"}),this.router.add("GET",":resourceType/:id/_history/:vid",Bc,{interaction:"vread"}),this.router.add("PUT",":resourceType/:id",qc,{interaction:"update"}),this.router.add("PUT",":resourceType",Hc,{interaction:"update"}),this.router.add("DELETE",":resourceType/:id",Jc,{interaction:"delete"}),this.router.add("DELETE",":resourceType",zc,{interaction:"delete"}),this.router.add("PATCH",":resourceType/:id",Xc,{interaction:"patch"}),this.router.add("POST","$graphql",To,{interaction:"operation"})}add(n,r,i,o){this.router.add(n,r,i,{interaction:o??"operation"})}find(n,r){return this.router.find(n,r)}async handleRequest(n,r){let i=n.url;if(n.pathname)throw new Dc(_e("FhirRequest must specify url instead of pathname"));let o=this.find(n.method,i);if(!o)return[kc];let{handler:s,path:a,params:c,query:p}=o;n.params=c,n.pathname=a,p&&(n.query=p);try{return await s(n,r,this)}catch(l){return[Fc(l)]}}log(n,r,i){let o={type:n,message:r,data:i};this.dispatchEvent(o)}};function Kc(e){if(!e)return;let t=/"([^"]+)"/.exec(e);return t?t[1]:void 0}function kg(e,t,n){return{method:e,url:t,pathname:"",query:{},params:{},body:n}}export{Xr as FhirRepository,go as FhirRouter,io as MemoryRepository,On as RepositoryMode,wn as Router,Gc as createResourceImpl,kg as makeSimpleRequest,Yc as updateResourceImpl};
55
55
  //# sourceMappingURL=index.mjs.map