@medplum/fhir-router 4.3.13 → 4.3.15

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
- "use strict";var co=Object.create;var Ft=Object.defineProperty;var uo=Object.getOwnPropertyDescriptor;var po=Object.getOwnPropertyNames;var lo=Object.getPrototypeOf,fo=Object.prototype.hasOwnProperty;var mo=(e,t)=>{for(var n in t)Ft(e,n,{get:t[n],enumerable:!0})},oi=(e,t,n,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of po(t))!fo.call(e,i)&&i!==n&&Ft(e,i,{get:()=>t[i],enumerable:!(r=uo(t,i))||r.enumerable});return e};var si=(e,t,n)=>(n=e!=null?co(lo(e)):{},oi(t||!e||!e.__esModule?Ft(n,"default",{value:e,enumerable:!0}):n,e)),ho=e=>oi(Ft({},"__esModule",{value:!0}),e);var cc={};mo(cc,{FhirRepository:()=>Sn,FhirRouter:()=>ti,MemoryRepository:()=>Hr,RepositoryMode:()=>Lt,Router:()=>At,createResourceImpl:()=>so,makeSimpleRequest:()=>ac,processBatch:()=>kt,updateResourceImpl:()=>ao});module.exports=ho(cc);var I=require("@medplum/core"),yo=50,To=8,go=/urn(:|%3A)uuid(:|%3A)[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}/,ai="urn:uuid";async function kt(e,t,n,r){return new Dn(n,t,r,e).run()}var Dn=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 I.OperationOutcomeError((0,I.badRequest)("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>yo)throw new I.OperationOutcomeError((0,I.badRequest)("Transaction contains more update operations than allowed"));if(r.requiresStrongTransaction&&n.length>To)throw new I.OperationOutcomeError((0,I.badRequest)("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 I.OperationOutcomeError((0,I.badRequest)("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]=st((0,I.badRequest)("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]=st(d);continue}throw new I.OperationOutcomeError(d)}let T=this.getRouteForEntry(p)?.data?.interaction;if(!T||!r[T])throw new I.OperationOutcomeError((0,I.badRequest)(`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(0,I.badRequest)("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 I.OperationOutcomeError)return o.outcome;throw o}if(i&&(this.resolvedIdentities[i.placeholder]=i.reference,this.isTransaction())){if(r.has(i.reference))throw new I.OperationOutcomeError((0,I.badRequest)("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 I.OperationOutcomeError(I.notFound);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(ai))return;let n=t.fullUrl;if(t.request?.ifNoneExist){let r=await this.repo.searchResources((0,I.parseSearchRequest)(t.request.url+"?"+t.request.ifNoneExist));if(r.length===1)return{placeholder:n,reference:(0,I.getReferenceString)(r[0])}}if(t.resource)return t.resource.id=this.repo.generateId(),{placeholder:n,reference:(0,I.getReferenceString)(t.resource)}}async resolveModificationIdentity(t,n){if(!t.fullUrl?.startsWith(ai))return;let r=t.fullUrl;if(t.request?.url?.includes("?")){let i=t.request.method,o=(0,I.parseSearchRequest)(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 I.OperationOutcomeError((0,I.badRequest)("Cannot provide ID for create by update"));return t.resource.id=this.repo.generateId(),{placeholder:r,reference:(0,I.getReferenceString)(t.resource)}}return;default:throw new I.OperationOutcomeError((0,I.badRequest)(`Conditional ${t.request.method} did not match any resources`,n+".request.url"))}if(a)throw new I.OperationOutcomeError((0,I.badRequest)(`Conditional ${t.request.method} matched multiple resources`,n+".request.url"));let c=(0,I.getReferenceString)(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 I.OperationOutcomeError((0,I.badRequest)("Missing bundle entry"));let o={type:"batch",bundleType:r,count:i.length,size:JSON.stringify(this.bundle).length};this.router.dispatchEvent(o);let s;for(let c=0;c<t.ordering.length;c++){let p=t.ordering[c],l=i[p],d=this.rewriteIdsInObject(l);try{n[p]=await this.processBatchEntry(d)}catch(m){if(this.isTransaction())throw m;if(s=(0,I.append)(s,m.message),m instanceof I.OperationOutcomeError&&(0,I.getStatus)(m.outcome)===429){for(let T=c;T<t.ordering.length;T++){let g=t.ordering[T];n[g]=st(m.outcome)}break}n[p]=st((0,I.normalizeOperationOutcome)(m));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 I.OperationOutcomeError(I.notFound);let r=this.parseBatchRequest(t,n),[i,o]=await n.handler(r,this.repo,this.router,{batch:!0});if(!(0,I.isOk)(i)&&this.isTransaction())throw new I.OperationOutcomeError(i);return st(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,config:this.req.config}}parsePatchBody(t){let n=t.resource,r;if(n?.resourceType==="Binary"){if(!n.data)throw new I.OperationOutcomeError((0,I.badRequest)("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 I.OperationOutcomeError((0,I.badRequest)("Patch entry must include a Binary or Parameters resource"));if(!Array.isArray(r))throw new I.OperationOutcomeError((0,I.badRequest)("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 I.OperationOutcomeError((0,I.badRequest)("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=go.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 st(e,t){return{response:{outcome:e,status:(0,I.getStatus)(e).toString(),location:(0,I.isOk)(e)&&t?.id?(0,I.getReferenceString)(t):void 0},resource:t}}var S=require("@medplum/core");var k=require("@medplum/core"),ro=si(require("dataloader"));function _(e,t){if(!!!e)throw new Error(t)}function ce(e){return typeof e?.then=="function"}function q(e){return typeof e=="object"&&e!==null}function $(e,t){if(!!!e)throw new Error(t??"Unexpected invariant triggered.")}var Eo=/\r\n|[\n\r]/g;function Qe(e,t){let n=0,r=1;for(let i of e.body.matchAll(Eo)){if(typeof i.index=="number"||$(!1),i.index>=t)break;n=i.index+i[0].length,r+=1}return{line:r,column:t+1-n}}function An(e){return Ct(e.source,Qe(e.source,e.start))}function Ct(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
+ "use strict";var co=Object.create;var Ft=Object.defineProperty;var uo=Object.getOwnPropertyDescriptor;var po=Object.getOwnPropertyNames;var lo=Object.getPrototypeOf,fo=Object.prototype.hasOwnProperty;var mo=(e,t)=>{for(var n in t)Ft(e,n,{get:t[n],enumerable:!0})},oi=(e,t,n,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of po(t))!fo.call(e,i)&&i!==n&&Ft(e,i,{get:()=>t[i],enumerable:!(r=uo(t,i))||r.enumerable});return e};var si=(e,t,n)=>(n=e!=null?co(lo(e)):{},oi(t||!e||!e.__esModule?Ft(n,"default",{value:e,enumerable:!0}):n,e)),ho=e=>oi(Ft({},"__esModule",{value:!0}),e);var uc={};mo(uc,{FhirRepository:()=>Sn,FhirRouter:()=>ti,MemoryRepository:()=>Hr,RepositoryMode:()=>Lt,Router:()=>At,createResourceImpl:()=>so,makeSimpleRequest:()=>cc,processBatch:()=>kt,updateResourceImpl:()=>ao});module.exports=ho(uc);var I=require("@medplum/core"),yo=50,To=8,go=/urn(:|%3A)uuid(:|%3A)[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}/,ai="urn:uuid";async function kt(e,t,n,r){return new Dn(n,t,r,e).run()}var Dn=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 I.OperationOutcomeError((0,I.badRequest)("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>yo)throw new I.OperationOutcomeError((0,I.badRequest)("Transaction contains more update operations than allowed"));if(r.requiresStrongTransaction&&n.length>To)throw new I.OperationOutcomeError((0,I.badRequest)("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 I.OperationOutcomeError((0,I.badRequest)("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]=st((0,I.badRequest)("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]=st(d);continue}throw new I.OperationOutcomeError(d)}let T=this.getRouteForEntry(p)?.data?.interaction;if(!T||!r[T])throw new I.OperationOutcomeError((0,I.badRequest)(`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(0,I.badRequest)("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 I.OperationOutcomeError)return o.outcome;throw o}if(i&&(this.resolvedIdentities[i.placeholder]=i.reference,this.isTransaction())){if(r.has(i.reference))throw new I.OperationOutcomeError((0,I.badRequest)("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 I.OperationOutcomeError(I.notFound);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(ai))return;let n=t.fullUrl;if(t.request?.ifNoneExist){let r=await this.repo.searchResources((0,I.parseSearchRequest)(t.request.url+"?"+t.request.ifNoneExist));if(r.length===1)return{placeholder:n,reference:(0,I.getReferenceString)(r[0])}}if(t.resource)return t.resource.id=this.repo.generateId(),{placeholder:n,reference:(0,I.getReferenceString)(t.resource)}}async resolveModificationIdentity(t,n){if(!t.fullUrl?.startsWith(ai))return;let r=t.fullUrl;if(t.request?.url?.includes("?")){let i=t.request.method,o=(0,I.parseSearchRequest)(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 I.OperationOutcomeError((0,I.badRequest)("Cannot provide ID for create by update"));return t.resource.id=this.repo.generateId(),{placeholder:r,reference:(0,I.getReferenceString)(t.resource)}}return;default:throw new I.OperationOutcomeError((0,I.badRequest)(`Conditional ${t.request.method} did not match any resources`,n+".request.url"))}if(a)throw new I.OperationOutcomeError((0,I.badRequest)(`Conditional ${t.request.method} matched multiple resources`,n+".request.url"));let c=(0,I.getReferenceString)(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 I.OperationOutcomeError((0,I.badRequest)("Missing bundle entry"));let o={type:"batch",bundleType:r,count:i.length,size:JSON.stringify(this.bundle).length};this.router.dispatchEvent(o);let s;for(let c=0;c<t.ordering.length;c++){let p=t.ordering[c],l=i[p],d=this.rewriteIdsInObject(l);try{n[p]=await this.processBatchEntry(d)}catch(m){if(this.isTransaction())throw m;if(s=(0,I.append)(s,m.message),m instanceof I.OperationOutcomeError&&(0,I.getStatus)(m.outcome)===429){for(let T=c;T<t.ordering.length;T++){let g=t.ordering[T];n[g]=st(m.outcome)}break}n[p]=st((0,I.normalizeOperationOutcome)(m));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 I.OperationOutcomeError(I.notFound);let r=this.parseBatchRequest(t,n),[i,o]=await n.handler(r,this.repo,this.router,{batch:!0});if(!(0,I.isOk)(i)&&this.isTransaction())throw new I.OperationOutcomeError(i);return st(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,config:this.req.config}}parsePatchBody(t){let n=t.resource,r;if(n?.resourceType==="Binary"){if(!n.data)throw new I.OperationOutcomeError((0,I.badRequest)("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 I.OperationOutcomeError((0,I.badRequest)("Patch entry must include a Binary or Parameters resource"));if(!Array.isArray(r))throw new I.OperationOutcomeError((0,I.badRequest)("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 I.OperationOutcomeError((0,I.badRequest)("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=go.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 st(e,t){return{response:{outcome:e,status:(0,I.getStatus)(e).toString(),location:(0,I.isOk)(e)&&t?.id?(0,I.getReferenceString)(t):void 0},resource:t}}var S=require("@medplum/core");var k=require("@medplum/core"),ro=si(require("dataloader"));function _(e,t){if(!!!e)throw new Error(t)}function ce(e){return typeof e?.then=="function"}function q(e){return typeof e=="object"&&e!==null}function $(e,t){if(!!!e)throw new Error(t??"Unexpected invariant triggered.")}var Eo=/\r\n|[\n\r]/g;function Qe(e,t){let n=0,r=1;for(let i of e.body.matchAll(Eo)){if(typeof i.index=="number"||$(!1),i.index>=t)break;n=i.index+i[0].length,r+=1}return{line:r,column:t+1-n}}function An(e){return Ct(e.source,Qe(e.source,e.start))}function Ct(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 m=Math.floor(c/80),T=c%80,g=[];for(let M=0;M<d.length;M+=80)g.push(d.slice(M,M+80));return p+ci([[`${s} |`,g[0]],...g.slice(1,m+1).map(M=>["|",M]),["|","^".padStart(T)],["|",g[m+1]]])}return p+ci([[`${s-1} |`,l[i-1]],[`${s} |`,d],["|","^".padStart(c)],[`${s+1} |`,l[i+1]]])}function ci(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 vo(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}=vo(n);super(t),this.name="GraphQLError",this.path=p??void 0,this.originalError=l??void 0,this.nodes=ui(Array.isArray(s)?s:s?[s]:void 0);let m=ui((r=this.nodes)===null||r===void 0?void 0:r.map(g=>g.loc).filter(g=>g!=null));this.source=a??(m==null||(i=m[0])===null||i===void 0?void 0:i.source),this.positions=c??m?.map(g=>g.start),this.locations=c&&a?c.map(g=>Qe(a,g)):m?.map(g=>Qe(g.source,g.start));let T=q(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
 
@@ -51,5 +51,5 @@ spurious results.`)}}return!1};var He=class{constructor(t,n="GraphQL request",r=
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 R(N),resolve:e=>e.name},description:{type:N,resolve:e=>e.description},isRepeatable:{type:new R(B),resolve:e=>e.isRepeatable},locations:{type:new R(new P(new R(qn))),resolve:e=>e.locations},args:{type:new R(new P(new R(It))),args:{includeDeprecated:{type:B,defaultValue:!1}},resolve(e,{includeDeprecated:t}){return t?e.args:e.args.filter(n=>n.deprecationReason==null)}}})}),qn=new be({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:b.QUERY,description:"Location adjacent to a query operation."},MUTATION:{value:b.MUTATION,description:"Location adjacent to a mutation operation."},SUBSCRIPTION:{value:b.SUBSCRIPTION,description:"Location adjacent to a subscription operation."},FIELD:{value:b.FIELD,description:"Location adjacent to a field."},FRAGMENT_DEFINITION:{value:b.FRAGMENT_DEFINITION,description:"Location adjacent to a fragment definition."},FRAGMENT_SPREAD:{value:b.FRAGMENT_SPREAD,description:"Location adjacent to a fragment spread."},INLINE_FRAGMENT:{value:b.INLINE_FRAGMENT,description:"Location adjacent to an inline fragment."},VARIABLE_DEFINITION:{value:b.VARIABLE_DEFINITION,description:"Location adjacent to a variable definition."},SCHEMA:{value:b.SCHEMA,description:"Location adjacent to a schema definition."},SCALAR:{value:b.SCALAR,description:"Location adjacent to a scalar definition."},OBJECT:{value:b.OBJECT,description:"Location adjacent to an object type definition."},FIELD_DEFINITION:{value:b.FIELD_DEFINITION,description:"Location adjacent to a field definition."},ARGUMENT_DEFINITION:{value:b.ARGUMENT_DEFINITION,description:"Location adjacent to an argument definition."},INTERFACE:{value:b.INTERFACE,description:"Location adjacent to an interface definition."},UNION:{value:b.UNION,description:"Location adjacent to a union definition."},ENUM:{value:b.ENUM,description:"Location adjacent to an enum definition."},ENUM_VALUE:{value:b.ENUM_VALUE,description:"Location adjacent to an enum value definition."},INPUT_OBJECT:{value:b.INPUT_OBJECT,description:"Location adjacent to an input object type definition."},INPUT_FIELD_DEFINITION:{value:b.INPUT_FIELD_DEFINITION,description:"Location adjacent to an input object field definition."}}}),de=new Y({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 R(Jn),resolve(e){if(Ee(e))return H.SCALAR;if(x(e))return H.OBJECT;if(w(e))return H.INTERFACE;if(X(e))return H.UNION;if(Q(e))return H.ENUM;if(D(e))return H.INPUT_OBJECT;if(C(e))return H.LIST;if(O(e))return H.NON_NULL;$(!1,`Unexpected type: "${y(e)}".`)}},name:{type:N,resolve:e=>"name"in e?e.name:void 0},description:{type:N,resolve:e=>"description"in e?e.description:void 0},specifiedByURL:{type:N,resolve:e=>"specifiedByURL"in e?e.specifiedByURL:void 0},fields:{type:new P(new R(Yn)),args:{includeDeprecated:{type:B,defaultValue:!1}},resolve(e,{includeDeprecated:t}){if(x(e)||w(e)){let n=Object.values(e.getFields());return t?n:n.filter(r=>r.deprecationReason==null)}}},interfaces:{type:new P(new R(de)),resolve(e){if(x(e)||w(e))return e.getInterfaces()}},possibleTypes:{type:new P(new R(de)),resolve(e,t,n,{schema:r}){if(oe(e))return r.getPossibleTypes(e)}},enumValues:{type:new P(new R(Hn)),args:{includeDeprecated:{type:B,defaultValue:!1}},resolve(e,{includeDeprecated:t}){if(Q(e)){let n=e.getValues();return t?n:n.filter(r=>r.deprecationReason==null)}}},inputFields:{type:new P(new R(It)),args:{includeDeprecated:{type:B,defaultValue:!1}},resolve(e,{includeDeprecated:t}){if(D(e)){let n=Object.values(e.getFields());return t?n:n.filter(r=>r.deprecationReason==null)}}},ofType:{type:de,resolve:e=>"ofType"in e?e.ofType:void 0},isOneOf:{type:B,resolve:e=>{if(D(e))return e.isOneOf}}})}),Yn=new Y({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 R(N),resolve:e=>e.name},description:{type:N,resolve:e=>e.description},args:{type:new R(new P(new R(It))),args:{includeDeprecated:{type:B,defaultValue:!1}},resolve(e,{includeDeprecated:t}){return t?e.args:e.args.filter(n=>n.deprecationReason==null)}},type:{type:new R(de),resolve:e=>e.type},isDeprecated:{type:new R(B),resolve:e=>e.deprecationReason!=null},deprecationReason:{type:N,resolve:e=>e.deprecationReason}})}),It=new Y({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 R(N),resolve:e=>e.name},description:{type:N,resolve:e=>e.description},type:{type:new R(de),resolve:e=>e.type},defaultValue:{type:N,description:"A GraphQL-formatted string representing the default value for this input value.",resolve(e){let{type:t,defaultValue:n}=e,r=nt(n,t);return r?A(r):null}},isDeprecated:{type:new R(B),resolve:e=>e.deprecationReason!=null},deprecationReason:{type:N,resolve:e=>e.deprecationReason}})}),Hn=new Y({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 R(N),resolve:e=>e.name},description:{type:N,resolve:e=>e.description},isDeprecated:{type:new R(B),resolve:e=>e.deprecationReason!=null},deprecationReason:{type:N,resolve:e=>e.deprecationReason}})}),H;(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"})(H||(H={}));var Jn=new be({name:"__TypeKind",description:"An enum describing what kind of type a given `__Type` is.",values:{SCALAR:{value:H.SCALAR,description:"Indicates this type is a scalar."},OBJECT:{value:H.OBJECT,description:"Indicates this type is an object. `fields` and `interfaces` are valid fields."},INTERFACE:{value:H.INTERFACE,description:"Indicates this type is an interface. `fields`, `interfaces`, and `possibleTypes` are valid fields."},UNION:{value:H.UNION,description:"Indicates this type is a union. `possibleTypes` is a valid field."},ENUM:{value:H.ENUM,description:"Indicates this type is an enum. `enumValues` is a valid field."},INPUT_OBJECT:{value:H.INPUT_OBJECT,description:"Indicates this type is an input object. `inputFields` is a valid field."},LIST:{value:H.LIST,description:"Indicates this type is a list. `ofType` is a valid field."},NON_NULL:{value:H.NON_NULL,description:"Indicates this type is a non-null. `ofType` is a valid field."}}}),Fe={name:"__schema",type:new R(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},ke={name:"__type",type:de,description:"Request the type information of a single type.",args:[{name:"name",description:void 0,type:new R(N),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},Ce={name:"__typename",type:new R(N),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},en=Object.freeze([Nt,Bn,qn,de,Yn,It,Hn,Jn]);function zn(e){return en.some(({name:t})=>e.name===t)}function Xn(e){return ne(e,Me)}function tn(e){if(!Xn(e))throw new Error(`Expected ${y(e)} to be a GraphQL schema.`);return e}var Me=class{constructor(t){var n,r;this.__validationErrors=t.assumeValid===!0?[]:void 0,q(t)||_(!1,"Must provide configuration object."),!t.types||Array.isArray(t.types)||_(!1,`"types" must be Array if provided but got: ${y(t.types)}.`),!t.directives||Array.isArray(t.directives)||_(!1,`"directives" must be Array if provided but got: ${y(t.directives)}.`),this.description=t.description,this.extensions=ie(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:Ne;let i=new Set(t.types);if(t.types!=null)for(let o of t.types)i.delete(o),Ie(o,i);this._queryType!=null&&Ie(this._queryType,i),this._mutationType!=null&&Ie(this._mutationType,i),this._subscriptionType!=null&&Ie(this._subscriptionType,i);for(let o of this._directives)if(vt(o))for(let s of o.args)Ie(s.type,i);Ie(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||_(!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,w(o)){for(let a of o.getInterfaces())if(w(a)){let c=this._implementationsMap[a.name];c===void 0&&(c=this._implementationsMap[a.name]={objects:[],interfaces:[]}),c.interfaces.push(o)}}else if(x(o)){for(let a of o.getInterfaces())if(w(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 U.QUERY:return this.getQueryType();case U.MUTATION:return this.getMutationType();case U.SUBSCRIPTION:return this.getSubscriptionType()}}getTypeMap(){return this._typeMap}getType(t){return this.getTypeMap()[t]}getPossibleTypes(t){return X(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),X(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 Ie(e,t){let n=z(e);if(!t.has(n)){if(t.add(n),X(n))for(let r of n.getTypes())Ie(r,t);else if(x(n)||w(n)){for(let r of n.getInterfaces())Ie(r,t);for(let r of Object.values(n.getFields())){Ie(r.type,t);for(let i of r.args)Ie(i.type,t)}}else if(D(n))for(let r of Object.values(n.getFields()))Ie(r.type,t)}return t}function Fi(e){if(tn(e),e.__validationErrors)return e.__validationErrors;let t=new Wn(e);Yo(t),Ho(t),Jo(t);let n=t.getErrors();return e.__validationErrors=n,n}function Rt(e){let t=Fi(e);if(t.length!==0)throw new Error(t.map(n=>n.message).join(`
52
52
 
53
53
  `))}var Wn=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 Yo(e){let t=e.schema,n=t.getQueryType();if(!n)e.reportError("Query root type must be provided.",t.astNode);else if(!x(n)){var r;e.reportError(`Query root type must be Object type, it cannot be ${y(n)}.`,(r=Kn(t,U.QUERY))!==null&&r!==void 0?r:n.astNode)}let i=t.getMutationType();if(i&&!x(i)){var o;e.reportError(`Mutation root type must be Object type if provided, it cannot be ${y(i)}.`,(o=Kn(t,U.MUTATION))!==null&&o!==void 0?o:i.astNode)}let s=t.getSubscriptionType();if(s&&!x(s)){var a;e.reportError(`Subscription root type must be Object type if provided, it cannot be ${y(s)}.`,(a=Kn(t,U.SUBSCRIPTION))!==null&&a!==void 0?a:s.astNode)}}function Kn(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 Ho(e){for(let n of e.schema.getDirectives()){if(!vt(n)){e.reportError(`Expected directive but got: ${y(n)}.`,n?.astNode);continue}Pe(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(Pe(e,r),K(r.type)||e.reportError(`The type of @${n.name}(${r.name}:) must be Input Type but got: ${y(r.type)}.`,r.astNode),Oe(r)&&r.deprecationReason!=null){var t;e.reportError(`Required argument @${n.name}(${r.name}:) cannot be deprecated.`,[Zn(r.astNode),(t=r.astNode)===null||t===void 0?void 0:t.type])}}}function Pe(e,t){t.name.startsWith("__")&&e.reportError(`Name "${t.name}" must not begin with "__", which is reserved by GraphQL introspection.`,t.astNode)}function Jo(e){let t=ts(e),n=e.schema.getTypeMap();for(let r of Object.values(n)){if(!Yt(r)){e.reportError(`Expected GraphQL named type but got: ${y(r)}.`,r.astNode);continue}zn(r)||Pe(e,r),x(r)||w(r)?(wi(e,r),Di(e,r)):X(r)?Ko(e,r):Q(r)?Wo(e,r):D(r)&&(Zo(e,r),t(r))}}function wi(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(Pe(e,s),!Re(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(Pe(e,a),!K(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(Oe(a)&&a.deprecationReason!=null){var o;e.reportError(`Required argument ${t.name}.${s.name}(${c}:) cannot be deprecated.`,[Zn(a.astNode),(o=a.astNode)===null||o===void 0?void 0:o.type])}}}}function Di(e,t){let n=Object.create(null);for(let r of t.getInterfaces()){if(!w(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,Xo(e,t,r),zo(e,t,r)}}function zo(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(!_e(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 m=d.name,T=l.args.find(g=>g.name===m);if(!T){e.reportError(`Interface field argument ${n.name}.${p}(${m}:) expected but ${t.name}.${p} does not provide it.`,[d.astNode,l.astNode]);continue}if(!zt(d.type,T.type)){var s,a;e.reportError(`Interface field argument ${n.name}.${p}(${m}:) expects type ${y(d.type)} but ${t.name}.${p}(${m}:) 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 m=d.name;!c.args.find(g=>g.name===m)&&Oe(d)&&e.reportError(`Object field ${t.name}.${p} includes required argument ${m} that is missing from the Interface field ${n.name}.${p}.`,[d.astNode,c.astNode])}}}function Xo(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 Ko(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.`,Ai(t,i.name));continue}r[i.name]=!0,x(i)||e.reportError(`Union type ${t.name} can only include Object types, it cannot include ${y(i)}.`,Ai(t,String(i)))}}function Wo(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)Pe(e,r)}function Zo(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(Pe(e,o),!K(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(et(o)&&o.deprecationReason!=null){var i;e.reportError(`Required input field ${t.name}.${o.name} cannot be deprecated.`,[Zn(o.astNode),(i=o.astNode)===null||i===void 0?void 0:i.type])}t.isOneOf&&es(t,o,e)}}function es(e,t,n){if(O(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 ts(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(O(a.type)&&D(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(m=>m.name).join(".");e.reportError(`Cannot reference Input Object "${c.name}" within itself through a series of non-null fields: "${d}".`,l.map(m=>m.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 Ai(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 Zn(e){var t;return e==null||(t=e.directives)===null||t===void 0?void 0:t.find(n=>n.name.value===Zt.name)}function V(e,t){switch(t.kind){case u.LIST_TYPE:{let n=V(e,t.type);return n&&new P(n)}case u.NON_NULL_TYPE:{let n=V(e,t.type);return n&&new R(n)}case u.NAMED_TYPE:return e.getType(t.name.value)}}var rt=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??ns,n&&(K(n)&&this._inputTypeStack.push(n),ue(n)&&this._parentTypeStack.push(n),Re(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=z(this.getType());this._parentTypeStack.push(ue(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(Re(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(x(i)?i:void 0);break}case u.INLINE_FRAGMENT:case u.FRAGMENT_DEFINITION:{let i=t.typeCondition,o=i?V(n,i):z(this.getType());this._typeStack.push(Re(o)?o:void 0);break}case u.VARIABLE_DEFINITION:{let i=V(n,t.type);this._inputTypeStack.push(K(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(K(o)?o:void 0);break}case u.LIST:{let i=Ze(this.getInputType()),o=C(i)?i.ofType:i;this._defaultValueStack.push(void 0),this._inputTypeStack.push(K(o)?o:void 0);break}case u.OBJECT_FIELD:{let i=z(this.getInputType()),o,s;D(i)&&(s=i.getFields()[t.name.value],s&&(o=s.type)),this._defaultValueStack.push(s?s.defaultValue:void 0),this._inputTypeStack.push(K(o)?o:void 0);break}case u.ENUM:{let i=z(this.getInputType()),o;Q(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 ns(e,t,n){let r=n.name.value;if(r===Fe.name&&e.getQueryType()===t)return Fe;if(r===ke.name&&e.getQueryType()===t)return ke;if(r===Ce.name&&ue(t))return Ce;if(x(t)||w(t))return t.getFields()[r]}function nn(e,t){return{enter(...n){let r=n[0];e.enter(r);let i=Xe(t,r.kind).enter;if(i){let o=i.apply(t,n);return o!==void 0&&(e.leave(r),ct(o)&&e.enter(o)),o}},leave(...n){let r=n[0],i=Xe(t,r.kind).leave,o;return i&&(o=i.apply(t,n)),e.leave(r),o}}}function er(e){return e.kind===u.OPERATION_DEFINITION||e.kind===u.FRAGMENT_DEFINITION}function tr(e){return e.kind===u.SCHEMA_DEFINITION||xe(e)||e.kind===u.DIRECTIVE_DEFINITION}function xe(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 nr(e){return e.kind===u.SCHEMA_EXTENSION||rn(e)}function rn(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 rr(e){return{Document(t){for(let n of t.definitions)if(!er(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 ir(e){return{Field(t){let n=e.getParentType();if(n&&!e.getFieldDef()){let i=e.getSchema(),o=t.name.value,s=ee("to use an inline fragment on",rs(i,n,o));s===""&&(s=ee(is(n,o))),e.reportError(new f(`Cannot query field "${o}" on type "${n.name}".`+s,{nodes:t}))}}}}function rs(e,t,n){if(!oe(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:w(s)&&e.isSubType(s,a)?-1:w(a)&&e.isSubType(a,s)?1:Je(s.name,a.name)}).map(s=>s.name)}function is(e,t){if(x(e)||w(e)){let n=Object.keys(e.getFields());return re(t,n)}return[]}function or(e){return{InlineFragment(t){let n=t.typeCondition;if(n){let r=V(e.getSchema(),n);if(r&&!ue(r)){let i=A(n);e.reportError(new f(`Fragment cannot condition on non composite type "${i}".`,{nodes:n}))}}},FragmentDefinition(t){let n=V(e.getSchema(),t.typeCondition);if(n&&!ue(n)){let r=A(t.typeCondition);e.reportError(new f(`Fragment "${t.name.value}" cannot condition on non composite type "${r}".`,{nodes:t.typeCondition}))}}}}function sr(e){return{...ar(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=re(o,s);e.reportError(new f(`Unknown argument "${o}" on field "${i.name}.${r.name}".`+ee(a),{nodes:t}))}}}}function ar(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():Ne;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=re(l,c);e.reportError(new f(`Unknown argument "${l}" on directive "@${a}".`+ee(d),{nodes:p}))}}return!1}}}function on(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():Ne;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 m=os(p);m&&!d.includes(m)&&e.reportError(new f(`Directive "@${l}" may not be used on ${m}.`,{nodes:o}))}}}function os(e){let t=e[e.length-1];switch("kind"in t||$(!1),t.kind){case u.OPERATION_DEFINITION:return ss(t.operation);case u.FIELD:return b.FIELD;case u.FRAGMENT_SPREAD:return b.FRAGMENT_SPREAD;case u.INLINE_FRAGMENT:return b.INLINE_FRAGMENT;case u.FRAGMENT_DEFINITION:return b.FRAGMENT_DEFINITION;case u.VARIABLE_DEFINITION:return b.VARIABLE_DEFINITION;case u.SCHEMA_DEFINITION:case u.SCHEMA_EXTENSION:return b.SCHEMA;case u.SCALAR_TYPE_DEFINITION:case u.SCALAR_TYPE_EXTENSION:return b.SCALAR;case u.OBJECT_TYPE_DEFINITION:case u.OBJECT_TYPE_EXTENSION:return b.OBJECT;case u.FIELD_DEFINITION:return b.FIELD_DEFINITION;case u.INTERFACE_TYPE_DEFINITION:case u.INTERFACE_TYPE_EXTENSION:return b.INTERFACE;case u.UNION_TYPE_DEFINITION:case u.UNION_TYPE_EXTENSION:return b.UNION;case u.ENUM_TYPE_DEFINITION:case u.ENUM_TYPE_EXTENSION:return b.ENUM;case u.ENUM_VALUE_DEFINITION:return b.ENUM_VALUE;case u.INPUT_OBJECT_TYPE_DEFINITION:case u.INPUT_OBJECT_TYPE_EXTENSION:return b.INPUT_OBJECT;case u.INPUT_VALUE_DEFINITION:{let n=e[e.length-3];return"kind"in n||$(!1),n.kind===u.INPUT_OBJECT_TYPE_DEFINITION?b.INPUT_FIELD_DEFINITION:b.ARGUMENT_DEFINITION}default:$(!1,"Unexpected kind: "+y(t.kind))}}function ss(e){switch(e){case U.QUERY:return b.QUERY;case U.MUTATION:return b.MUTATION;case U.SUBSCRIPTION:return b.SUBSCRIPTION}}function cr(e){return{FragmentSpread(t){let n=t.name.value;e.getFragment(n)||e.reportError(new f(`Unknown fragment "${n}".`,{nodes:t.name}))}}}function sn(e){let t=e.getSchema(),n=t?t.getTypeMap():Object.create(null),r=Object.create(null);for(let o of e.getDocument().definitions)xe(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 m=(d=p[2])!==null&&d!==void 0?d:a,T=m!=null&&as(m);if(T&&ki.includes(l))return;let g=re(l,T?ki.concat(i):i);e.reportError(new f(`Unknown type "${l}".`+ee(g),{nodes:o}))}}}}var ki=[...Xt,...en].map(e=>e.name);function as(e){return"kind"in e&&(tr(e)||nr(e))}function ur(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 pr(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 cs=3;function lr(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>=cs))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 fr(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),m=d.slice(0,-1).map(T=>'"'+T.name.value+'"').join(", ");e.reportError(new f(`Cannot spread fragment "${p}" within itself`+(m!==""?` via ${m}.`:"."),{nodes:d}))}n.pop()}r[s]=void 0}}}function dr(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 mr(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 hr(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 an(e){switch(e.kind){case u.OBJECT:return{...e,fields:us(e.fields)};case u.LIST:return{...e,values:e.values.map(an)};case u.INT:case u.FLOAT:case u.STRING:case u.BOOLEAN:case u.NULL:case u.ENUM:case u.VARIABLE:return e}}function us(e){return e.map(t=>({...t,value:an(t.value)})).sort((t,n)=>Je(t.name.value,n.name.value))}function Mi(e){return Array.isArray(e)?e.map(([t,n])=>`subfields "${t}" conflict because `+Mi(n)).join(" and "):e}function Er(e){let t=new ln,n=new gr,r=new Map;return{SelectionSet(i){let o=ps(e,r,t,n,e.getParentType(),i);for(let[[s,a],c,p]of o){let l=Mi(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 ps(e,t,n,r,i,o){let s=[],[a,c]=pn(e,t,i,o);if(fs(e,s,t,n,r,a),c.length!==0)for(let p=0;p<c.length;p++){cn(e,s,t,n,r,!1,a,c[p]);for(let l=p+1;l<c.length;l++)un(e,s,t,n,r,!1,c[p],c[l])}return s}function cn(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]=Tr(e,n,c);if(s!==p){vr(e,t,n,r,i,o,s,p);for(let d of l)cn(e,t,n,r,i,o,s,d)}}function un(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]=Tr(e,n,c),[m,T]=Tr(e,n,p);vr(e,t,n,r,i,o,l,m);for(let g of T)un(e,t,n,r,i,o,s,g);for(let g of d)un(e,t,n,r,i,o,g,a)}function ls(e,t,n,r,i,o,s,a,c){let p=[],[l,d]=pn(e,t,o,s),[m,T]=pn(e,t,a,c);vr(e,p,t,n,r,i,l,m);for(let g of T)cn(e,p,t,n,r,i,l,g);for(let g of d)cn(e,p,t,n,r,i,m,g);for(let g of d)for(let M of T)un(e,p,t,n,r,i,g,M);return p}function fs(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=Pi(e,n,r,i,!1,s,a[c],a[p]);l&&t.push(l)}}function vr(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 m of l){let T=Pi(e,n,r,i,o,c,d,m);T&&t.push(T)}}}function Pi(e,t,n,r,i,o,s,a){let[c,p,l]=s,[d,m,T]=a,g=i||c!==d&&x(c)&&x(d);if(!g){let ae=p.name.value,he=m.name.value;if(ae!==he)return[[o,`"${ae}" and "${he}" are different fields`],[p],[m]];if(!ds(p,m))return[[o,"they have differing arguments"],[p],[m]]}let M=l?.type,Z=T?.type;if(M&&Z&&yr(M,Z))return[[o,`they return conflicting types "${y(M)}" and "${y(Z)}"`],[p],[m]];let J=p.selectionSet,fe=m.selectionSet;if(J&&fe){let ae=ls(e,t,n,r,g,z(M),J,z(Z),fe);return ms(ae,o,p,m)}}function ds(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:Ci(s)===Ci(a)})}function Ci(e){return A(an(e))}function yr(e,t){return C(e)?C(t)?yr(e.ofType,t.ofType):!0:C(t)?!0:O(e)?O(t)?yr(e.ofType,t.ofType):!0:O(t)?!0:W(e)||W(t)?e!==t:!1}function pn(e,t,n,r){let i=t.get(r);if(i)return i;let o=Object.create(null),s=Object.create(null);Ui(e,n,r,o,s);let a=[o,Object.keys(s)];return t.set(r,a),a}function Tr(e,t,n){let r=t.get(n.selectionSet);if(r)return r;let i=V(e.getSchema(),n.typeCondition);return pn(e,t,i,n.selectionSet)}function Ui(e,t,n,r,i){for(let o of n.selections)switch(o.kind){case u.FIELD:{let s=o.name.value,a;(x(t)||w(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?V(e.getSchema(),s):t;Ui(e,a,o.selectionSet,r,i);break}}}function ms(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 ln=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)}},gr=class{constructor(){this._orderedPairSet=new ln}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 Nr(e){return{InlineFragment(t){let n=e.getType(),r=e.getParentType();if(ue(n)&&ue(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=hs(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 hs(e,t){let n=e.getFragment(t);if(n){let r=V(e.getSchema(),n.typeCondition);if(ue(r))return r}}function Ir(e){let t=e.getSchema(),n=Object.create(null);for(let i of e.getDocument().definitions)xe(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=ys[s.kind]:a&&(c=Ts(a)),c){if(c!==i.kind){let p=gs(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=re(o,p);e.reportError(new f(`Cannot extend type "${o}" because it is not defined.`+ee(l),{nodes:i.name}))}}}var ys={[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 Ts(e){if(Ee(e))return u.SCALAR_TYPE_EXTENSION;if(x(e))return u.OBJECT_TYPE_EXTENSION;if(w(e))return u.INTERFACE_TYPE_EXTENSION;if(X(e))return u.UNION_TYPE_EXTENSION;if(Q(e))return u.ENUM_TYPE_EXTENSION;if(D(e))return u.INPUT_OBJECT_TYPE_EXTENSION;$(!1,"Unexpected type: "+y(e))}function gs(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:$(!1,"Unexpected kind: "+y(e))}}function br(e){return{...Rr(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)&&Oe(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 Rr(e){var t;let n=Object.create(null),r=e.getSchema(),i=(t=r?.getDirectives())!==null&&t!==void 0?t:Ne;for(let a of i)n[a.name]=ye(a.args.filter(Oe),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]=ye(c.filter(Es),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:[],m=new Set(d.map(T=>T.name.value));for(let[T,g]of Object.entries(p))if(!m.has(T)){let M=We(g.type)?y(g.type):A(g.type);e.reportError(new f(`Directive "@${c}" argument "${T}" of type "${M}" is required, but it was not provided.`,{nodes:a}))}}}}}}function Es(e){return e.type.kind===u.NON_NULL_TYPE&&e.defaultValue==null}function Or(e){return{Field(t){let n=e.getType(),r=t.selectionSet;if(n)if(W(z(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 fn(e){return e.map(t=>typeof t=="number"?"["+t.toString()+"]":"."+t).join("")}function Ue(e,t,n){return{prev:e,key:t,typename:n}}function te(e){let t=[],n=e;for(;n;)t.push(n.key),n=n.prev;return t.reverse()}function $i(e,t,n=vs){return Ot(e,t,n,void 0)}function vs(e,t,n){let r="Invalid value "+y(t);throw e.length>0&&(r+=` at "value${fn(e)}"`),n.message=r+": "+n.message,n}function Ot(e,t,n,r){if(O(t)){if(e!=null)return Ot(e,t.ofType,n,r);n(te(r),e,new f(`Expected non-nullable type "${y(t)}" not to be null.`));return}if(e==null)return null;if(C(t)){let i=t.ofType;return tt(e)?Array.from(e,(o,s)=>{let a=Ue(r,s,void 0);return Ot(o,i,n,a)}):[Ot(e,i,n,r)]}if(D(t)){if(!q(e)||Array.isArray(e)){n(te(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(O(s.type)){let c=y(s.type);n(te(r),e,new f(`Field "${s.name}" of required type "${c}" was not provided.`))}continue}i[s.name]=Ot(a,s.type,n,Ue(r,s.name,t.name))}for(let s of Object.keys(e))if(!o[s]){let a=re(s,Object.keys(t.getFields()));n(te(r),e,new f(`Field "${s}" is not defined by type "${t.name}".`+ee(a)))}if(t.isOneOf){let s=Object.keys(i);s.length!==1&&n(te(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(te(r).concat(a),c,new f(`Field "${a}" must be non-null.`))}return i}if(W(t)){let i;try{i=t.parseValue(e)}catch(o){o instanceof f?n(te(r),e,o):n(te(r),e,new f(`Expected type "${t.name}". `+o.message,{originalError:o}));return}return i===void 0&&n(te(r),e,new f(`Expected type "${t.name}".`)),i}$(!1,"Unexpected input type: "+y(t))}function $e(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&&O(t)?void 0:i}if(O(t))return e.kind===u.NULL?void 0:$e(e,t.ofType,n);if(e.kind===u.NULL)return null;if(C(t)){let r=t.ofType;if(e.kind===u.LIST){let o=[];for(let s of e.values)if(Vi(s,n)){if(O(r))return;o.push(null)}else{let a=$e(s,r,n);if(a===void 0)return;o.push(a)}return o}let i=$e(e,r,n);return i===void 0?void 0:[i]}if(D(t)){if(e.kind!==u.OBJECT)return;let r=Object.create(null),i=ye(e.fields,o=>o.name.value);for(let o of Object.values(t.getFields())){let s=i[o.name];if(!s||Vi(s.value,n)){if(o.defaultValue!==void 0)r[o.name]=o.defaultValue;else if(O(o.type))return;continue}let a=$e(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(W(t)){let r;try{r=t.parseLiteral(e,n)}catch{return}return r===void 0?void 0:r}$(!1,"Unexpected input type: "+y(t))}}function Vi(e,t){return e.kind===u.VARIABLE&&(t==null||t[e.name.value]===void 0)}function Sr(e,t,n,r){let i=[],o=r?.maxErrors;try{let s=Ns(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 Ns(e,t,n,r){let i={};for(let o of t){let s=o.variable.name.value,a=V(e,o.type);if(!K(a)){let p=A(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(!Gi(n,s)){if(o.defaultValue)i[s]=$e(o.defaultValue,a);else if(O(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&&O(a)){let p=y(a);r(new f(`Variable "$${s}" of non-null type "${p}" must not be null.`,{nodes:o}));continue}i[s]=$i(c,a,(p,l,d)=>{let m=`Variable "$${s}" got invalid value `+y(l);p.length>0&&(m+=` at "${s}${fn(p)}"`),r(new f(m+"; "+d.message,{nodes:o,originalError:d}))})}return i}function dn(e,t,n){var r;let i={},o=(r=t.arguments)!==null&&r!==void 0?r:[],s=ye(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(O(p))throw new f(`Argument "${c}" of required type "${y(p)}" was not provided.`,{nodes:t});continue}let d=l.value,m=d.kind===u.NULL;if(d.kind===u.VARIABLE){let g=d.name.value;if(n==null||!Gi(n,g)){if(a.defaultValue!==void 0)i[c]=a.defaultValue;else if(O(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}m=n[g]==null}if(m&&O(p))throw new f(`Argument "${c}" of non-null type "${y(p)}" must not be null.`,{nodes:d});let T=$e(d,p,n);if(T===void 0)throw new f(`Argument "${c}" has invalid value ${A(d)}.`,{nodes:d});i[c]=T}return i}function mn(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 dn(e,i,n)}function Gi(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function yn(e,t,n,r,i){let o=new Map;return hn(e,t,n,r,i,o,new Set),o}function Qi(e,t,n,r,i){let o=new Map,s=new Set;for(let a of i)a.selectionSet&&hn(e,t,n,r,a.selectionSet,o,s);return o}function hn(e,t,n,r,i,o,s){for(let a of i.selections)switch(a.kind){case u.FIELD:{if(!_r(n,a))continue;let c=Is(a),p=o.get(c);p!==void 0?p.push(a):o.set(c,[a]);break}case u.INLINE_FRAGMENT:{if(!_r(n,a)||!ji(e,a,r))continue;hn(e,t,n,r,a.selectionSet,o,s);break}case u.FRAGMENT_SPREAD:{let c=a.name.value;if(s.has(c)||!_r(n,a))continue;s.add(c);let p=t[c];if(!p||!ji(e,p,r))continue;hn(e,t,n,r,p.selectionSet,o,s);break}}}function _r(e,t){let n=mn(Wt,t,e);if(n?.if===!0)return!1;let r=mn(Kt,t,e);return r?.if!==!1}function ji(e,t,n){let r=t.typeCondition;if(!r)return!0;let i=V(e,r);return i===n?!0:oe(i)?e.isSubType(i,n):!1}function Is(e){return e.alias?e.alias.value:e.name.value}function xr(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=yn(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 it(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 Lr(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=it(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 Tn(e){return{Field:t,Directive:t};function t(n){var r;let i=(r=n.arguments)!==null&&r!==void 0?r:[],o=it(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 wr(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 gn(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():Ne;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(xe(a)||rn(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 Dr(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,m=n[a];Q(m)&&m.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 Ar(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;bs(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 bs(e,t){return x(e)||w(e)||D(e)?e.getFields()[t]!=null:!1}function Fr(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 En(e){let t=[],n=Object.create(null);return{ObjectValue:{enter(){t.push(n),n=Object.create(null)},leave(){let r=t.pop();r||$(!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 kr(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 Cr(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 Mr(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 Pr(e){return{OperationDefinition(t){var n;let r=(n=t.variableDefinitions)!==null&&n!==void 0?n:[],i=it(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 Ur(e){let t={};return{OperationDefinition:{enter(){t={}}},VariableDefinition(n){t[n.variable.name.value]=n},ListValue(n){let r=Ze(e.getParentInputType());if(!C(r))return Ve(e,n),!1},ObjectValue(n){let r=z(e.getInputType());if(!D(r))return Ve(e,n),!1;let i=ye(n.fields,o=>o.name.value);for(let o of Object.values(r.getFields()))if(!i[o.name]&&et(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&&Rs(e,n,r,i,t)},ObjectField(n){let r=z(e.getParentInputType());if(!e.getInputType()&&D(r)){let o=re(n.name.value,Object.keys(r.getFields()));e.reportError(new f(`Field "${n.name.value}" is not defined by type "${r.name}".`+ee(o),{nodes:n}))}},NullValue(n){let r=e.getInputType();O(r)&&e.reportError(new f(`Expected value of type "${y(r)}", found ${A(n)}.`,{nodes:n}))},EnumValue:n=>Ve(e,n),IntValue:n=>Ve(e,n),FloatValue:n=>Ve(e,n),StringValue:n=>Ve(e,n),BooleanValue:n=>Ve(e,n)}}function Ve(e,t){let n=e.getInputType();if(!n)return;let r=z(n);if(!W(r)){let i=y(n);e.reportError(new f(`Expected value of type "${i}", found ${A(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 ${A(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 ${A(t)}; `+i.message,{nodes:t,originalError:i}))}}function Rs(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 $r(e){return{VariableDefinition(t){let n=V(e.getSchema(),t.type);if(n!==void 0&&!K(n)){let r=t.variable.name.value,i=A(t.type);e.reportError(new f(`Variable "$${r}" cannot be non-input type "${i}".`,{nodes:t.type}))}}}}function Vr(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,parentType:a}of r){let c=i.name.value,p=t[c];if(p&&o){let l=e.getSchema(),d=V(l,p.type);if(d&&!Os(l,d,p.defaultValue,o,s)){let m=y(d),T=y(o);e.reportError(new f(`Variable "$${c}" of type "${m}" used in position expecting type "${T}".`,{nodes:[p,i]}))}D(a)&&a.isOneOf&&yt(d)&&e.reportError(new f(`Variable "$${c}" is of type "${d}" but must be non-nullable to be used for OneOf Input Object "${a}".`,{nodes:[p,i]}))}}}},VariableDefinition(n){t[n.variable.name.value]=n}}}function Os(e,t,n,r,i){if(O(r)&&!O(t)){if(!(n!=null&&n.kind!==u.NULL)&&!(i!==void 0))return!1;let a=r.ofType;return _e(e,t,a)}return _e(e,t,r)}var Gr=Object.freeze([lr]),ot=Object.freeze([rr,kr,ur,xr,sn,or,$r,Or,ir,Fr,cr,mr,Nr,fr,Pr,dr,hr,on,gn,sr,Tn,Ur,br,Vr,Er,En,...Gr]),Ss=Object.freeze([pr,Cr,Mr,Dr,Ar,Lr,wr,sn,on,gn,Ir,ar,Tn,En,Rr]);var jr=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 jr{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 rt(this._schema);we(t,nn(i,{VariableDefinition:()=>!1,Variable(o){r.push({node:o,type:i.getInputType(),defaultValue:i.getDefaultValue(),parentType:i.getParentInputType()})}})),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 vn(e,t,n=ot,r,i=new rt(e)){var o;let s=(o=r?.maxErrors)!==null&&o!==void 0?o:100;t||_(!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=$n(n.map(d=>d(p)));try{we(t,nn(i,l))}catch(d){if(d!==a)throw d}return c}function Bi(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 qi(e,t,n){let r=n;for(let i of e)r=ce(r)?r.then(o=>t(o,i)):t(r,i);return r}function Yi(e){return e instanceof Error?e:new Br(e)}var Br=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=Yi(e);return _s(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 _s(e){return Array.isArray(e.path)}var xs=Bi((e,t,n)=>Qi(e.schema,e.fragments,e.variableValues,t,n));function On(e){arguments.length<2||_(!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;Ls(t,n,r);let o=ws(e);if(!("schema"in o))return{errors:o};try{let{operation:s}=o,a=Ds(o,s,i);return ce(a)?a.then(c=>Nn(c,o.errors),c=>(o.errors.push(c),Nn(null,o.errors))):Nn(a,o.errors)}catch(s){return o.errors.push(s),Nn(null,o.errors)}}function Nn(e,t){return t.length===0?{data:e}:{errors:t,data:e}}function Ls(e,t,n){t||_(!1,"Must provide document."),Rt(e),n==null||q(n)||_(!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 ws(e){var t,n,r;let{schema:i,document:o,rootValue:s,contextValue:a,variableValues:c,operationName:p,fieldResolver:l,typeResolver:d,subscribeFieldResolver:m,options:T}=e,g,M=Object.create(null);for(let fe of o.definitions)switch(fe.kind){case u.OPERATION_DEFINITION:if(p==null){if(g!==void 0)return[new f("Must provide operation name if query contains multiple operations.")];g=fe}else((t=fe.name)===null||t===void 0?void 0:t.value)===p&&(g=fe);break;case u.FRAGMENT_DEFINITION:M[fe.name.value]=fe;break;default:}if(!g)return p!=null?[new f(`Unknown operation named "${p}".`)]:[new f("Must provide an operation.")];let Z=(n=g.variableDefinitions)!==null&&n!==void 0?n:[],J=Sr(i,Z,c??{},{maxErrors:(r=T?.maxCoercionErrors)!==null&&r!==void 0?r:50});return J.errors?J.errors:{schema:i,fragments:M,rootValue:s,contextValue:a,operation:g,variableValues:J.coerced,fieldResolver:l??Rn,typeResolver:d??Yr,subscribeFieldResolver:m??Rn,errors:[]}}function Ds(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=yn(e.schema,e.fragments,e.variableValues,r,t.selectionSet),o=void 0;switch(t.operation){case U.QUERY:return In(e,r,n,o,i);case U.MUTATION:return As(e,r,n,o,i);case U.SUBSCRIPTION:return In(e,r,n,o,i)}}function As(e,t,n,r,i){return qi(i.entries(),(o,[s,a])=>{let c=Ue(r,s,t.name),p=zi(e,t,n,a,c);return p===void 0?o:ce(p)?p.then(l=>(o[s]=l,o)):(o[s]=p,o)},Object.create(null))}function In(e,t,n,r,i){let o=Object.create(null),s=!1;try{for(let[a,c]of i.entries()){let p=Ue(r,a,t.name),l=zi(e,t,n,c,p);l!==void 0&&(o[a]=l,ce(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=Ps(e.schema,t,r[0]);if(!s)return;let a=s.type,c=(o=s.resolve)!==null&&o!==void 0?o:e.fieldResolver,p=Fs(e,s,r,t,i);try{let l=dn(s,r[0],e.variableValues),d=e.contextValue,m=c(n,l,d,p),T;return ce(m)?T=m.then(g=>xt(e,a,r,p,i,g)):T=xt(e,a,r,p,i,m),ce(T)?T.then(void 0,g=>{let M=_t(g,r,te(i));return bn(M,a,e)}):T}catch(l){let d=_t(l,r,te(i));return bn(d,a,e)}}function Fs(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 bn(e,t,n){if(O(t))throw e;return n.errors.push(e),null}function xt(e,t,n,r,i,o){if(o instanceof Error)throw o;if(O(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(C(t))return ks(e,t,n,r,i,o);if(W(t))return Cs(t,o);if(oe(t))return Ms(e,t,n,r,i,o);if(x(t))return qr(e,t,n,r,i,o);$(!1,"Cannot complete value of unexpected output type: "+y(t))}function ks(e,t,n,r,i,o){if(!tt(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=Ue(i,l,void 0);try{let m;return ce(p)?m=p.then(T=>xt(e,s,n,r,d,T)):m=xt(e,s,n,r,d,p),ce(m)?(a=!0,m.then(void 0,T=>{let g=_t(T,n,te(d));return bn(g,s,e)})):m}catch(m){let T=_t(m,n,te(d));return bn(T,s,e)}});return a?Promise.all(c):c}function Cs(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 Ms(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 ce(p)?p.then(l=>qr(e,Hi(l,e,t,n,r,o),n,r,i,o)):qr(e,Hi(p,e,t,n,r,o),n,r,i,o)}function Hi(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(x(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(!x(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 qr(e,t,n,r,i,o){let s=xs(e,t,n);if(t.isTypeOf){let a=t.isTypeOf(o,e.contextValue,r);if(ce(a))return a.then(c=>{if(!c)throw Ji(t,o,n);return In(e,t,o,i,s)});if(!a)throw Ji(t,o,n)}return In(e,t,o,i,s)}function Ji(e,t,n){return new f(`Expected value of type "${e.name}" but got: ${y(t)}.`,{nodes:n})}var Yr=function(e,t,n,r){if(q(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(ce(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})},Rn=function(e,t,n,r){if(q(e)||typeof e=="function"){let i=e[r.fieldName];return typeof i=="function"?e[r.fieldName](t,n,r):i}};function Ps(e,t,n){let r=n.name.value;return r===Fe.name&&e.getQueryType()===t?Fe:r===ke.name&&e.getQueryType()===t?ke:r===Ce.name?Ce:t.getFields()[r]}var E=require("@medplum/core"),Xi=require("rfc6902"),Lt={READER:"reader",WRITER:"writer"},Sn=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 E.OperationOutcomeError((0,E.badRequest)("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 E.OperationOutcomeError((0,E.badRequest)("Resource ID did not match resolved ID",t.resourceType+".id"));return{resource:i[0],outcome:E.allOk}}else if(i.length>1)throw new E.OperationOutcomeError(E.multipleMatches);return{resource:await this.createResource(t,r),outcome:E.created}},{serializable:!0})}async conditionalUpdate(t,n,r){if(n.resourceType!==t.resourceType)throw new E.OperationOutcomeError((0,E.badRequest)("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 E.OperationOutcomeError((0,E.badRequest)("Cannot perform create as update with client-assigned ID",t.resourceType+".id"));return{resource:await this.createResource(t,r),outcome:E.created}}else if(i.length>1)throw new E.OperationOutcomeError(E.multipleMatches);let o=i[0];if(t.id&&t.id!==o.id)throw new E.OperationOutcomeError((0,E.badRequest)("Resource ID did not match resolved ID",t.resourceType+".id"));return{resource:await this.updateResource({...t,id:o.id},r),outcome:E.allOk}},{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 E.OperationOutcomeError(E.multipleMatches);if(!n.length)return;let r=n[0];await this.deleteResource(r.resourceType,r.id)},{serializable:!0})}async conditionalPatch(t,n){return t.count=2,t.sortRules=void 0,this.withTransaction(async()=>{let r=await this.searchResources(t);if(r.length>1)throw new E.OperationOutcomeError(E.multipleMatches);if(!r.length)throw new E.OperationOutcomeError(E.notFound);let i=r[0];return this.patchResource(i.resourceType,i.id,n)},{serializable:!0})}},Hr=class extends Sn{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((0,E.stringify)(t));n.id||(n.id=this.generateId()),n.meta||(n.meta={}),n.meta.versionId||(n.meta.versionId=(0,E.generateId)()),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),(0,E.deepClone)(n)}generateId(){return(0,E.generateId)()}updateResource(t,n){if(!t.id)throw new E.OperationOutcomeError((0,E.badRequest)("Missing id"));if(n?.ifMatch){let i=n.ifMatch,o=this.resources.get(t.resourceType)?.get(t.id);if(!o)throw new E.OperationOutcomeError(E.notFound);if(o.meta?.versionId!==i)throw new E.OperationOutcomeError(E.preconditionFailed)}let r=(0,E.deepClone)(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=(0,Xi.applyPatch)(i,r).filter(Boolean);if(o.length>0)throw new E.OperationOutcomeError((0,E.badRequest)(o.map(s=>s.message).join(`
54
- `)))}catch(o){throw new E.OperationOutcomeError((0,E.normalizeOperationOutcome)(o))}return this.updateResource(i)}async readResource(t,n){let r=this.resources.get(t)?.get(n);if(!r)throw new E.OperationOutcomeError(E.notFound);return(0,E.deepClone)(r)}async readReference(t){let n=t.reference?.split("/");if(!n||n.length!==2)throw new E.OperationOutcomeError((0,E.badRequest)("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:(0,E.deepClone)(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 E.OperationOutcomeError(E.notFound);return(0,E.deepClone)(i)}async search(t){let{resourceType:n}=t,r=this.resources.get(n)??new Map,i=[];for(let s of r.values())(0,E.matchesSearchRequest)(s,t)&&i.push(s);let o=i.map(s=>({resource:(0,E.deepClone)(s)}));if(t.sortRules)for(let s of t.sortRules)o=o.sort((a,c)=>sa(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:E.Operator.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 E.OperationOutcomeError(E.notFound);this.resources.get(t)?.delete(n)}withTransaction(t){return t(void 0)}},sa=(e,t,n)=>{let i=E.globalSchema.types[e.resourceType]?.searchParams?.[n.code]?.expression;if(!i)return 0;let o=JSON.stringify((0,E.evalFhirPath)(i,e)),s=JSON.stringify((0,E.evalFhirPath)(i,t));return o.localeCompare(s)*(n.descending?-1:1)};var Ge=require("@medplum/core");var me=require("@medplum/core"),Ki=si(require("dataloader"));var _n={base64Binary:N,boolean:B,canonical:N,code:N,date:N,dateTime:N,decimal:le,id:ve,instant:N,integer:le,markdown:N,number:le,oid:N,positiveInt:le,string:N,time:N,unsignedInt:le,uri:N,url:N,uuid:N,xhtml:N,"http://hl7.org/fhirpath/System.Boolean":B,"http://hl7.org/fhirpath/System.Date":N,"http://hl7.org/fhirpath/System.DateTime":N,"http://hl7.org/fhirpath/System.Decimal":le,"http://hl7.org/fhirpath/System.Integer":le,"http://hl7.org/fhirpath/System.String":N,"http://hl7.org/fhirpath/System.Time":N};function Wi(e,t,n){let r;if(t){let o=n._reference;delete n._reference,r={code:o,operator:me.Operator.EQUALS,value:(0,me.getReferenceString)(t)}}return n=Object.fromEntries(Object.entries(n).map(([o,s])=>[aa(o),s])),{searchRequest:(0,me.parseSearchRequest)(e,n),referenceFilter:r}}function Zi(e,t){let n=e.filters||[];e.filters=[t,...n]}function eo(e,t,n){let{searchRequest:r,referenceFilter:i}=Wi(e,t,n);return i&&Zi(r,i),r}function Jr(e,t){e.count=Math.min(e.count??me.DEFAULT_SEARCH_COUNT,t??me.DEFAULT_MAX_SEARCH_COUNT)}function aa(e){return e.startsWith("_")?e:e.replaceAll("_","-")}function zr(e){return e.replaceAll("-","_")}function ca(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 xn(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}=Wi(o,e,t);Jr(s,n.config?.graphqlMaxSearches);let c=n.config?.graphqlBatchedSearchSize??0;if(c===0||!a)return a&&Zi(s,a),(await n.repo.search(s)).entry?.map(m=>m.resource);let p=ca(s);return(n.searchDataLoaders[p]??=ua(n.repo,s,c)).load(a)}function ua(e,t,n){return new Ki.default(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 wt(e){let t={_count:{type:pe,description:"Specify how many elements to return from a repeating list."},_offset:{type:pe,description:"Specify the offset to start at for a repeating element."},_sort:{type:N,description:"Specify the sort order by comma-separated list of sort rules in priority order."},_id:{type:N,description:"Select resources based on the logical id of the resource."},_lastUpdated:{type:N,description:"Select resources based on the last time they were changed."},_filter:{type:N,description:" The _filter parameter provides a syntax for expressing a set of query expressions on the underlying resources."}},n=(0,me.getSearchParameters)(e);if(n)for(let[r,i]of Object.entries(n))t[zr(r)]={type:N,description:i.description};return t}function Xr(e,t){return e.fieldNodes.some(n=>n.selectionSet?.selections.some(r=>r.kind===u.FIELD&&r.name.value===t))}function to(e){return{resourceType:"OperationOutcome",issue:e.map(t=>({severity:"error",code:"invalid",details:{text:t.message}}))}}var no={..._n};function Dt(e,t){let n=no[e];return n||(n=pa(e,t),no[e]=n),n}function pa(e,t){let n=(0,Ge.getDataType)(e);return new Ae({name:e+t,description:n.description,fields:()=>la(e,t)})}function la(e,t){let n={};if((0,Ge.isResourceType)(e)){let r={description:"The type of resource",type:N};n.resourceType=r}return fa(e,n,t),n}function fa(e,t,n){let r=(0,Ge.getDataType)(e);for(let[i,o]of Object.entries(r.elements))for(let s of o.type)da(t,i,o,s,n)}function da(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:Dt(o,i)};n.max>1&&(s.type=new P(new R(Dt(o,i)))),n.min>0&&!t.endsWith("[x]")&&(s.type=new R(s.type));let a=t.split(".").pop().replace("[x]",(0,Ge.capitalize)(r.code));e[a]=s}var F=require("@medplum/core");var Ln={..._n};function je(e){let t=Ln[e];return t||(t=Kr(e),Ln[e]=t),t}function Kr(e){if(e==="ResourceList")return new De({name:"ResourceList",types:()=>(0,F.getResourceTypes)().map(je).filter(n=>!!n),resolveType:ba});let t=(0,F.getDataType)(e);return new Y({name:e,description:t.description,fields:()=>ma(e)})}function ma(e){let t={};return ha(e,t),Ea(e,t),t}function ha(e,t){let n=(0,F.getDataType)(e);(0,F.isResourceTypeSchema)(n)&&(t.resourceType={type:new R(N),description:"Resource Type"}),e==="Reference"&&(t.resource={description:"Reference",type:je("ResourceList"),resolve:Ia});for(let[r,i]of Object.entries(n.elements))for(let o of i.type)ya(t,r,i,o)}function ya(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:va(n,i,t),resolve:Na};n.max>1&&(o.args=Ta(i));let s=t.split(".").pop().replace("[x]",(0,F.capitalize)(r.code));e[s]=o}function Ta(e){let t={_count:{type:pe,description:"Specify how many elements to return from a repeating list."},_offset:{type:pe,description:"Specify the offset to start at for a repeating element."}};if(!(0,F.isLowerCase)(e.charAt(0))){t.fhirpath={type:N,description:"A FHIRPath statement selecting which of the subnodes is to be included"};let n=(0,F.tryGetDataType)(e);if(n?.elements)for(let[r,i]of Object.entries(n.elements))for(let o of i.type)ga(t,r,i,o)}return t}function ga(e,t,n,r){let i=r.code,o=t.replace("[x]",(0,F.capitalize)(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:N,description:n.description};break}}function Ea(e,t){for(let n of(0,F.getResourceTypes)()){let r=je(n),i=(0,F.getSearchParameters)(n),o={},s=0;if(i)for(let[a,c]of Object.entries(i))c.target?.includes(e)&&(o[zr(a)]={value:a},s++);if(s>0){let a=new be({name:e+"_"+n+"_reference",values:o}),c=wt(n);c._reference={type:new R(a),description:`Specify which property to use for reverse lookup for ${n}`},t[n+"List"]={type:new P(r),args:c,resolve:xn}}}}function va(e,t,n){let r=je(t);return e.max>1&&(r=new P(new R(r))),e.min!==0&&!n.endsWith("[x]")&&(r=new R(r)),r}async function Na(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(m=>m[l]===d);return a&&(p=p.filter(l=>(0,F.toJsBoolean)((0,F.evalFhirPathTyped)(a,[(0,F.toTypedValue)(l)])))),o&&(p=p.slice(o)),s&&(p=p.slice(0,s)),p}async function Ia(e,t,n){if((0,F.isReference)(e))try{return await n.dataLoader.load(e)}catch(r){throw new F.OperationOutcomeError((0,F.normalizeOperationOutcome)(r),r)}}function ba(e){let t=e?.resourceType;if(t)return je(t).name}var Ra=new k.LRUCache,Wr;async function io(e,t,n,r){let{query:i,operationName:o,variables:s}=e.body;if(!i)return[(0,k.badRequest)("Must provide query.")];let a;try{a=Gt(i)}catch{return[(0,k.badRequest)("GraphQL syntax error.")]}let c=_a(),p=[...ot,Ua(n,e.config?.graphqlMaxDepth),Va(n)],l=vn(c,a,p);if(l.length>0)return[to(l)];let d=Oa(i);if(d&&!n.options?.introspectionEnabled)return[k.forbidden];!r?.batch&&!Sa(i)&&t.setMode(Lt.READER);let m=new ro.default(g=>t.readReferences(g)),T=d&&Ra.get(i);if(!T){let g={repo:t,config:e.config,dataLoader:m,searchCount:0,searchDataLoaders:Object.create(null)};T=await On({schema:c,document:a,contextValue:g,operationName:o,variableValues:s})}return[k.allOk,T,{contentType:k.ContentType.JSON}]}function Oa(e){return e.includes("query IntrospectionQuery")||e.includes("__schema")}function Sa(e){return e.includes("mutation")}function _a(){return Wr||(Wr=xa()),Wr}function xa(){for(let n of(0,k.getResourceTypes)())Ln[n]=Kr(n);let e={},t={};for(let n of(0,k.getResourceTypes)()){let r=je(n);e[n]={type:r,args:{id:{type:new R(ve),description:n+" ID"}},resolve:Fa},e[n+"List"]={type:new P(r),args:wt(n),resolve:xn},e[n+"Connection"]={type:Da(n,r),args:wt(n),resolve:Aa},t[n+"Create"]={type:r,args:La(n),resolve:ka},t[n+"Update"]={type:r,args:wa(n),resolve:Ca},t[n+"Delete"]={type:r,args:{id:{type:new R(ve),description:n+" ID"}},resolve:Ma}}return new Me({query:new Y({name:"QueryType",fields:e}),mutation:new Y({name:"MutationType",fields:t})})}function La(e){return{res:{type:new R(Dt(e,"Create")),description:e+" Create"}}}function wa(e){return{id:{type:new R(ve),description:e+" ID"},res:{type:new R(Dt(e,"Update")),description:e+" Update"}}}function Da(e,t){return new Y({name:e+"Connection",fields:{count:{type:pe},offset:{type:pe},pageSize:{type:pe},first:{type:N},previous:{type:N},next:{type:N},last:{type:N},edges:{type:new P(new Y({name:e+"ConnectionEdge",fields:{mode:{type:N},score:{type:le},resource:{type:t}}}))}}})}async function Aa(e,t,n,r){let i=r.fieldName,o=i.substring(0,i.length-10),s=eo(o,e,t);Xr(r,"count")&&(s.total="accurate"),Xr(r,"edges")||(s.count=0),Jr(s,n.config?.graphqlMaxSearches);let a=await n.repo.search(s);return{count:a.total,offset:s.offset??0,pageSize:s.count??k.DEFAULT_SEARCH_COUNT,edges:a.entry?.map(c=>({mode:c.search?.mode,score:c.search?.score,resource:c.resource}))}}async function Fa(e,t,n,r){try{return await n.dataLoader.load({reference:`${r.fieldName}/${t.id}`})}catch(i){throw new k.OperationOutcomeError((0,k.normalizeOperationOutcome)(i),i)}}async function ka(e,t,n,r){let i=r.fieldName,o=i.substring(0,i.length-6),s=t.res;if(s.resourceType!==o)throw new k.OperationOutcomeError((0,k.badRequest)("Invalid resourceType"));return n.repo.createResource((0,k.deepClone)(s))}async function Ca(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 k.OperationOutcomeError((0,k.badRequest)("Invalid resourceType"));if(a!==s.id)throw new k.OperationOutcomeError((0,k.badRequest)("Invalid ID"));return n.repo.updateResource((0,k.deepClone)(s))}async function Ma(e,t,n,r){let i=r.fieldName,o=i.substring(0,i.length-6);await n.repo.deleteResource(o,t.id)}var Pa=12,Ua=(e,t=Pa)=>n=>new Zr(n,e,t),Zr=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}},$a=1e4,Va=(e,t)=>n=>new ei(n,e,t),ei=class{constructor(t,n,r){this.context=t,this.maxCost=r?.maxCost??$a,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;Ga(r)?(this.log("Found search field",r.name.value),i=8,o=this.getCount(r.arguments)??20):ja(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 Ga(e){return e.name.value.endsWith("List")}function ja(e){return e.name.value==="resource"}var At=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=Qa(c,t,o);p>a&&(s=c,a=p)}if(s)return{handler:s.handler,path:o.join("/"),params:Ba(s,o),query:i?qa(n):void 0,data:s.data}}};function Qa(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 Ba(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 qa(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 Ya(e,t,n){let r=e.body;if(r.resourceType!=="Bundle")return[(0,S.badRequest)("Not a bundle")];let i=await kt(e,t,n,r);return[S.allOk,i]}async function Ha(e,t,n,r){ni(e,t,r);let{resourceType:i}=e.params,o=await t.search((0,S.parseSearchRequest)(i,e.query));return[S.allOk,o]}async function Ja(e,t,n,r){ni(e,t,r);let i=(0,S.parseSearchRequest)("MultipleTypes",e.query);if(!i.types||i.types.length===0)return[(0,S.badRequest)("No types specified")];let o=await t.search(i);return[S.allOk,o]}async function za(e,t,n,r){ni(e,t,r);let{resourceType:i}=e.params,o=e.body,s=await t.search((0,S.parseSearchRequest)(i,o));return[S.allOk,s]}function ni(e,t,n){!n?.batch&&e.config?.searchOnReader&&t.setMode(Lt.READER)}async function Xa(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=(0,S.singularize)(e.headers["if-none-exist"]),c=await t.conditionalCreate(o,(0,S.parseSearchRequest)(`${i}?${a}`),{assignedId:s});return[c.outcome,c.resource]}return so(i,o,t,{assignedId:s})}async function so(e,t,n,r){if(t.resourceType!==e)return[(0,S.badRequest)(`Incorrect resource type: expected ${e}, but found ${t.resourceType||"<EMPTY>"}`)];let i=await n.createResource(t,r);return[S.created,i]}async function Ka(e,t){let{resourceType:n,id:r}=e.params,i=await t.readResource(n,r);return[S.allOk,i]}async function Wa(e,t){let{resourceType:n,id:r}=e.params,i=oo(e.query,"_offset"),o=oo(e.query,"_count"),s=await t.readHistory(n,r,{offset:i,limit:o});return[S.allOk,s]}async function Za(e,t){let{resourceType:n,id:r,vid:i}=e.params,o=await t.readVersion(n,r,i);return[S.allOk,o]}async function ec(e,t){let{resourceType:n,id:r}=e.params,i=e.body;return ao(n,r,i,t,{ifMatch:sc(e.headers?.["if-match"])})}async function ao(e,t,n,r,i){if(n.resourceType!==e)return[(0,S.badRequest)("Incorrect resource type")];if(n.id!==t)return[(0,S.badRequest)("Incorrect resource ID")];let o=await r.updateResource(n,i);return[S.allOk,o]}async function tc(e,t,n,r){let{resourceType:i}=e.params,o=e.body,s=(0,S.parseSearchRequest)(i,e.query),a=await t.conditionalUpdate(o,s,{assignedId:r?.batch});return[a.outcome,a.resource]}async function nc(e,t){let{resourceType:n,id:r}=e.params;return await t.deleteResource(n,r),[S.allOk]}async function rc(e,t){let{resourceType:n}=e.params,r=(0,S.parseSearchRequest)(n,e.query);return await t.conditionalDelete(r),[S.allOk]}async function ic(e,t){let{resourceType:n,id:r}=e.params,i=e.body;if(!i)return[(0,S.badRequest)("Empty patch body")];if(!Array.isArray(i))return[(0,S.badRequest)("Patch body must be an array")];let o=await t.patchResource(n,r,i);return[S.allOk,o]}async function oc(e,t){let{resourceType:n}=e.params,r=e.body;if(!r)return[(0,S.badRequest)("Empty patch body")];if(!Array.isArray(r))return[(0,S.badRequest)("Patch body must be an array")];let i=(0,S.parseSearchRequest)(n,e.query),o=await t.conditionalPatch(i,r);return[S.allOk,o]}var ti=class extends S.EventTarget{constructor(n={}){super();this.router=new At;this.options=n,this.router.add("GET","",Ja,{interaction:"search-system"}),this.router.add("POST","",Ya,{interaction:"batch"}),this.router.add("GET",":resourceType",Ha,{interaction:"search-type"}),this.router.add("POST",":resourceType/_search",za,{interaction:"search-type"}),this.router.add("POST",":resourceType",Xa,{interaction:"create"}),this.router.add("GET",":resourceType/:id",Ka,{interaction:"read"}),this.router.add("GET",":resourceType/:id/_history",Wa,{interaction:"history-instance"}),this.router.add("GET",":resourceType/:id/_history/:vid",Za,{interaction:"vread"}),this.router.add("PUT",":resourceType/:id",ec,{interaction:"update"}),this.router.add("PUT",":resourceType",tc,{interaction:"update"}),this.router.add("DELETE",":resourceType/:id",nc,{interaction:"delete"}),this.router.add("DELETE",":resourceType",rc,{interaction:"delete"}),this.router.add("PATCH",":resourceType/:id",ic,{interaction:"patch"}),this.router.add("PATCH",":resourceType",oc,{interaction:"patch"}),this.router.add("POST","$graphql",io,{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 S.OperationOutcomeError((0,S.badRequest)("FhirRequest must specify url instead of pathname"));let o=this.find(n.method,i);if(!o)return[S.notFound];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[(0,S.normalizeOperationOutcome)(l)]}}log(n,r,i){let o={type:n,message:r,data:i};this.dispatchEvent(o)}};function sc(e){if(!e)return;let t=/"([^"]+)"/.exec(e);return t?t[1]:void 0}function oo(e,t){let n=e[t],r;return Array.isArray(n)?r=n[n.length-1]:r=n,r?parseInt(r,10):void 0}function ac(e,t,n){return{method:e,url:t,pathname:"",query:{},params:{},body:n}}0&&(module.exports={FhirRepository,FhirRouter,MemoryRepository,RepositoryMode,Router,createResourceImpl,makeSimpleRequest,processBatch,updateResourceImpl});
54
+ `)))}catch(o){throw new E.OperationOutcomeError((0,E.normalizeOperationOutcome)(o))}return this.updateResource(i)}async readResource(t,n){let r=this.resources.get(t)?.get(n);if(!r)throw new E.OperationOutcomeError(E.notFound);return(0,E.deepClone)(r)}async readReference(t){let n=t.reference?.split("/");if(!n||n.length!==2)throw new E.OperationOutcomeError((0,E.badRequest)("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:(0,E.deepClone)(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 E.OperationOutcomeError(E.notFound);return(0,E.deepClone)(i)}async search(t){let{resourceType:n}=t,r=this.resources.get(n)??new Map,i=[];for(let s of r.values())(0,E.matchesSearchRequest)(s,t)&&i.push(s);let o=i.map(s=>({resource:(0,E.deepClone)(s)}));if(t.sortRules)for(let s of t.sortRules)o=o.sort((a,c)=>sa(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:E.Operator.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 E.OperationOutcomeError(E.notFound);this.resources.get(t)?.delete(n)}withTransaction(t){return t(void 0)}},sa=(e,t,n)=>{let i=E.globalSchema.types[e.resourceType]?.searchParams?.[n.code]?.expression;if(!i)return 0;let o=JSON.stringify((0,E.evalFhirPath)(i,e)),s=JSON.stringify((0,E.evalFhirPath)(i,t));return o.localeCompare(s)*(n.descending?-1:1)};var Ge=require("@medplum/core");var me=require("@medplum/core"),Ki=si(require("dataloader"));var _n={base64Binary:N,boolean:B,canonical:N,code:N,date:N,dateTime:N,decimal:le,id:ve,instant:N,integer:le,markdown:N,number:le,oid:N,positiveInt:le,string:N,time:N,unsignedInt:le,uri:N,url:N,uuid:N,xhtml:N,"http://hl7.org/fhirpath/System.Boolean":B,"http://hl7.org/fhirpath/System.Date":N,"http://hl7.org/fhirpath/System.DateTime":N,"http://hl7.org/fhirpath/System.Decimal":le,"http://hl7.org/fhirpath/System.Integer":le,"http://hl7.org/fhirpath/System.String":N,"http://hl7.org/fhirpath/System.Time":N};function Wi(e,t,n){let r;if(t){let o=n._reference;delete n._reference,r={code:o,operator:me.Operator.EQUALS,value:(0,me.getReferenceString)(t)}}return n=Object.fromEntries(Object.entries(n).map(([o,s])=>[aa(o),s])),{searchRequest:(0,me.parseSearchRequest)(e,n),referenceFilter:r}}function Zi(e,t){let n=e.filters||[];e.filters=[t,...n]}function eo(e,t,n){let{searchRequest:r,referenceFilter:i}=Wi(e,t,n);return i&&Zi(r,i),r}function Jr(e,t){e.count=Math.min(e.count??me.DEFAULT_SEARCH_COUNT,t??me.DEFAULT_MAX_SEARCH_COUNT)}function aa(e){return e.startsWith("_")?e:e.replaceAll("_","-")}function zr(e){return e.replaceAll("-","_")}function ca(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 xn(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}=Wi(o,e,t);Jr(s,n.config?.graphqlMaxSearches);let c=n.config?.graphqlBatchedSearchSize??0;if(c===0||!a)return a&&Zi(s,a),(await n.repo.search(s)).entry?.map(m=>m.resource);let p=ca(s);return(n.searchDataLoaders[p]??=ua(n.repo,s,c)).load(a)}function ua(e,t,n){return new Ki.default(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 wt(e){let t={_count:{type:pe,description:"Specify how many elements to return from a repeating list."},_offset:{type:pe,description:"Specify the offset to start at for a repeating element."},_sort:{type:N,description:"Specify the sort order by comma-separated list of sort rules in priority order."},_id:{type:N,description:"Select resources based on the logical id of the resource."},_lastUpdated:{type:N,description:"Select resources based on the last time they were changed."},_filter:{type:N,description:" The _filter parameter provides a syntax for expressing a set of query expressions on the underlying resources."},_cursor:{type:N,description:"The _cursor parameter is used to retrieve the next page of results from a previous search."}},n=(0,me.getSearchParameters)(e);if(n)for(let[r,i]of Object.entries(n))t[zr(r)]={type:N,description:i.description};return t}function Xr(e,t){return e.fieldNodes.some(n=>n.selectionSet?.selections.some(r=>r.kind===u.FIELD&&r.name.value===t))}function to(e){return{resourceType:"OperationOutcome",issue:e.map(t=>({severity:"error",code:"invalid",details:{text:t.message}}))}}var no={..._n};function Dt(e,t){let n=no[e];return n||(n=pa(e,t),no[e]=n),n}function pa(e,t){let n=(0,Ge.getDataType)(e);return new Ae({name:e+t,description:n.description,fields:()=>la(e,t)})}function la(e,t){let n={};if((0,Ge.isResourceType)(e)){let r={description:"The type of resource",type:N};n.resourceType=r}return fa(e,n,t),n}function fa(e,t,n){let r=(0,Ge.getDataType)(e);for(let[i,o]of Object.entries(r.elements))for(let s of o.type)da(t,i,o,s,n)}function da(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:Dt(o,i)};n.max>1&&(s.type=new P(new R(Dt(o,i)))),n.min>0&&!t.endsWith("[x]")&&(s.type=new R(s.type));let a=t.split(".").pop().replace("[x]",(0,Ge.capitalize)(r.code));e[a]=s}var F=require("@medplum/core");var Ln={..._n};function je(e){let t=Ln[e];return t||(t=Kr(e),Ln[e]=t),t}function Kr(e){if(e==="ResourceList")return new De({name:"ResourceList",types:()=>(0,F.getResourceTypes)().map(je).filter(n=>!!n),resolveType:ba});let t=(0,F.getDataType)(e);return new Y({name:e,description:t.description,fields:()=>ma(e)})}function ma(e){let t={};return ha(e,t),Ea(e,t),t}function ha(e,t){let n=(0,F.getDataType)(e);(0,F.isResourceTypeSchema)(n)&&(t.resourceType={type:new R(N),description:"Resource Type"}),e==="Reference"&&(t.resource={description:"Reference",type:je("ResourceList"),resolve:Ia});for(let[r,i]of Object.entries(n.elements))for(let o of i.type)ya(t,r,i,o)}function ya(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:va(n,i,t),resolve:Na};n.max>1&&(o.args=Ta(i));let s=t.split(".").pop().replace("[x]",(0,F.capitalize)(r.code));e[s]=o}function Ta(e){let t={_count:{type:pe,description:"Specify how many elements to return from a repeating list."},_offset:{type:pe,description:"Specify the offset to start at for a repeating element."}};if(!(0,F.isLowerCase)(e.charAt(0))){t.fhirpath={type:N,description:"A FHIRPath statement selecting which of the subnodes is to be included"};let n=(0,F.tryGetDataType)(e);if(n?.elements)for(let[r,i]of Object.entries(n.elements))for(let o of i.type)ga(t,r,i,o)}return t}function ga(e,t,n,r){let i=r.code,o=t.replace("[x]",(0,F.capitalize)(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:N,description:n.description};break}}function Ea(e,t){for(let n of(0,F.getResourceTypes)()){let r=je(n),i=(0,F.getSearchParameters)(n),o={},s=0;if(i)for(let[a,c]of Object.entries(i))c.target?.includes(e)&&(o[zr(a)]={value:a},s++);if(s>0){let a=new be({name:e+"_"+n+"_reference",values:o}),c=wt(n);c._reference={type:new R(a),description:`Specify which property to use for reverse lookup for ${n}`},t[n+"List"]={type:new P(r),args:c,resolve:xn}}}}function va(e,t,n){let r=je(t);return e.max>1&&(r=new P(new R(r))),e.min!==0&&!n.endsWith("[x]")&&(r=new R(r)),r}async function Na(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(m=>m[l]===d);return a&&(p=p.filter(l=>(0,F.toJsBoolean)((0,F.evalFhirPathTyped)(a,[(0,F.toTypedValue)(l)])))),o&&(p=p.slice(o)),s&&(p=p.slice(0,s)),p}async function Ia(e,t,n){if((0,F.isReference)(e))try{return await n.dataLoader.load(e)}catch(r){throw new F.OperationOutcomeError((0,F.normalizeOperationOutcome)(r),r)}}function ba(e){let t=e?.resourceType;if(t)return je(t).name}var Ra=new k.LRUCache,Wr;async function io(e,t,n,r){let{query:i,operationName:o,variables:s}=e.body;if(!i)return[(0,k.badRequest)("Must provide query.")];let a;try{a=Gt(i)}catch{return[(0,k.badRequest)("GraphQL syntax error.")]}let c=_a(),p=[...ot,Ua(n,e.config?.graphqlMaxDepth),Va(n)],l=vn(c,a,p);if(l.length>0)return[to(l)];let d=Oa(i);if(d&&!n.options?.introspectionEnabled)return[k.forbidden];!r?.batch&&!Sa(i)&&t.setMode(Lt.READER);let m=new ro.default(g=>t.readReferences(g)),T=d&&Ra.get(i);if(!T){let g={repo:t,config:e.config,dataLoader:m,searchCount:0,searchDataLoaders:Object.create(null)};T=await On({schema:c,document:a,contextValue:g,operationName:o,variableValues:s})}return[k.allOk,T,{contentType:k.ContentType.JSON}]}function Oa(e){return e.includes("query IntrospectionQuery")||e.includes("__schema")}function Sa(e){return e.includes("mutation")}function _a(){return Wr||(Wr=xa()),Wr}function xa(){for(let n of(0,k.getResourceTypes)())Ln[n]=Kr(n);let e={},t={};for(let n of(0,k.getResourceTypes)()){let r=je(n);e[n]={type:r,args:{id:{type:new R(ve),description:n+" ID"}},resolve:Fa},e[n+"List"]={type:new P(r),args:wt(n),resolve:xn},e[n+"Connection"]={type:Da(n,r),args:wt(n),resolve:Aa},t[n+"Create"]={type:r,args:La(n),resolve:ka},t[n+"Update"]={type:r,args:wa(n),resolve:Ca},t[n+"Delete"]={type:r,args:{id:{type:new R(ve),description:n+" ID"}},resolve:Ma}}return new Me({query:new Y({name:"QueryType",fields:e}),mutation:new Y({name:"MutationType",fields:t})})}function La(e){return{res:{type:new R(Dt(e,"Create")),description:e+" Create"}}}function wa(e){return{id:{type:new R(ve),description:e+" ID"},res:{type:new R(Dt(e,"Update")),description:e+" Update"}}}function Da(e,t){return new Y({name:e+"Connection",fields:{count:{type:pe},offset:{type:pe},pageSize:{type:pe},first:{type:N},previous:{type:N},next:{type:N},last:{type:N},edges:{type:new P(new Y({name:e+"ConnectionEdge",fields:{mode:{type:N},score:{type:le},resource:{type:t}}}))}}})}async function Aa(e,t,n,r){let i=r.fieldName,o=i.substring(0,i.length-10),s=eo(o,e,t);Xr(r,"count")&&(s.total="accurate"),Xr(r,"edges")||(s.count=0),Jr(s,n.config?.graphqlMaxSearches);let a=await n.repo.search(s);return{count:a.total,offset:s.offset??0,pageSize:s.count??k.DEFAULT_SEARCH_COUNT,edges:a.entry?.map(c=>({mode:c.search?.mode,score:c.search?.score,resource:c.resource})),next:Qa(a)}}async function Fa(e,t,n,r){try{return await n.dataLoader.load({reference:`${r.fieldName}/${t.id}`})}catch(i){throw new k.OperationOutcomeError((0,k.normalizeOperationOutcome)(i),i)}}async function ka(e,t,n,r){let i=r.fieldName,o=i.substring(0,i.length-6),s=t.res;if(s.resourceType!==o)throw new k.OperationOutcomeError((0,k.badRequest)("Invalid resourceType"));return n.repo.createResource((0,k.deepClone)(s))}async function Ca(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 k.OperationOutcomeError((0,k.badRequest)("Invalid resourceType"));if(a!==s.id)throw new k.OperationOutcomeError((0,k.badRequest)("Invalid ID"));return n.repo.updateResource((0,k.deepClone)(s))}async function Ma(e,t,n,r){let i=r.fieldName,o=i.substring(0,i.length-6);await n.repo.deleteResource(o,t.id)}var Pa=12,Ua=(e,t=Pa)=>n=>new Zr(n,e,t),Zr=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}},$a=1e4,Va=(e,t)=>n=>new ei(n,e,t),ei=class{constructor(t,n,r){this.context=t,this.maxCost=r?.maxCost??$a,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;Ga(r)?(this.log("Found search field",r.name.value),i=8,o=this.getCount(r.arguments)??20):ja(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 Ga(e){return e.name.value.endsWith("List")}function ja(e){return e.name.value==="resource"}function Qa(e){let t=e.link?.find(n=>n.relation==="next")?.url;if(t)return new URL(t).searchParams.get("_cursor")||void 0}var At=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=Ba(c,t,o);p>a&&(s=c,a=p)}if(s)return{handler:s.handler,path:o.join("/"),params:qa(s,o),query:i?Ya(n):void 0,data:s.data}}};function Ba(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 qa(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 Ya(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 Ha(e,t,n){let r=e.body;if(r.resourceType!=="Bundle")return[(0,S.badRequest)("Not a bundle")];let i=await kt(e,t,n,r);return[S.allOk,i]}async function Ja(e,t,n,r){ni(e,t,r);let{resourceType:i}=e.params,o=await t.search((0,S.parseSearchRequest)(i,e.query));return[S.allOk,o]}async function za(e,t,n,r){ni(e,t,r);let i=(0,S.parseSearchRequest)("MultipleTypes",e.query);if(!i.types||i.types.length===0)return[(0,S.badRequest)("No types specified")];let o=await t.search(i);return[S.allOk,o]}async function Xa(e,t,n,r){ni(e,t,r);let{resourceType:i}=e.params,o=e.body,s=await t.search((0,S.parseSearchRequest)(i,o));return[S.allOk,s]}function ni(e,t,n){!n?.batch&&e.config?.searchOnReader&&t.setMode(Lt.READER)}async function Ka(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=(0,S.singularize)(e.headers["if-none-exist"]),c=await t.conditionalCreate(o,(0,S.parseSearchRequest)(`${i}?${a}`),{assignedId:s});return[c.outcome,c.resource]}return so(i,o,t,{assignedId:s})}async function so(e,t,n,r){if(t.resourceType!==e)return[(0,S.badRequest)(`Incorrect resource type: expected ${e}, but found ${t.resourceType||"<EMPTY>"}`)];let i=await n.createResource(t,r);return[S.created,i]}async function Wa(e,t){let{resourceType:n,id:r}=e.params,i=await t.readResource(n,r);return[S.allOk,i]}async function Za(e,t){let{resourceType:n,id:r}=e.params,i=oo(e.query,"_offset"),o=oo(e.query,"_count"),s=await t.readHistory(n,r,{offset:i,limit:o});return[S.allOk,s]}async function ec(e,t){let{resourceType:n,id:r,vid:i}=e.params,o=await t.readVersion(n,r,i);return[S.allOk,o]}async function tc(e,t){let{resourceType:n,id:r}=e.params,i=e.body;return ao(n,r,i,t,{ifMatch:ac(e.headers?.["if-match"])})}async function ao(e,t,n,r,i){if(n.resourceType!==e)return[(0,S.badRequest)("Incorrect resource type")];if(n.id!==t)return[(0,S.badRequest)("Incorrect resource ID")];let o=await r.updateResource(n,i);return[S.allOk,o]}async function nc(e,t,n,r){let{resourceType:i}=e.params,o=e.body,s=(0,S.parseSearchRequest)(i,e.query),a=await t.conditionalUpdate(o,s,{assignedId:r?.batch});return[a.outcome,a.resource]}async function rc(e,t){let{resourceType:n,id:r}=e.params;return await t.deleteResource(n,r),[S.allOk]}async function ic(e,t){let{resourceType:n}=e.params,r=(0,S.parseSearchRequest)(n,e.query);return await t.conditionalDelete(r),[S.allOk]}async function oc(e,t){let{resourceType:n,id:r}=e.params,i=e.body;if(!i)return[(0,S.badRequest)("Empty patch body")];if(!Array.isArray(i))return[(0,S.badRequest)("Patch body must be an array")];let o=await t.patchResource(n,r,i);return[S.allOk,o]}async function sc(e,t){let{resourceType:n}=e.params,r=e.body;if(!r)return[(0,S.badRequest)("Empty patch body")];if(!Array.isArray(r))return[(0,S.badRequest)("Patch body must be an array")];let i=(0,S.parseSearchRequest)(n,e.query),o=await t.conditionalPatch(i,r);return[S.allOk,o]}var ti=class extends S.EventTarget{constructor(n={}){super();this.router=new At;this.options=n,this.router.add("GET","",za,{interaction:"search-system"}),this.router.add("POST","",Ha,{interaction:"batch"}),this.router.add("GET",":resourceType",Ja,{interaction:"search-type"}),this.router.add("POST",":resourceType/_search",Xa,{interaction:"search-type"}),this.router.add("POST",":resourceType",Ka,{interaction:"create"}),this.router.add("GET",":resourceType/:id",Wa,{interaction:"read"}),this.router.add("GET",":resourceType/:id/_history",Za,{interaction:"history-instance"}),this.router.add("GET",":resourceType/:id/_history/:vid",ec,{interaction:"vread"}),this.router.add("PUT",":resourceType/:id",tc,{interaction:"update"}),this.router.add("PUT",":resourceType",nc,{interaction:"update"}),this.router.add("DELETE",":resourceType/:id",rc,{interaction:"delete"}),this.router.add("DELETE",":resourceType",ic,{interaction:"delete"}),this.router.add("PATCH",":resourceType/:id",oc,{interaction:"patch"}),this.router.add("PATCH",":resourceType",sc,{interaction:"patch"}),this.router.add("POST","$graphql",io,{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 S.OperationOutcomeError((0,S.badRequest)("FhirRequest must specify url instead of pathname"));let o=this.find(n.method,i);if(!o)return[S.notFound];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[(0,S.normalizeOperationOutcome)(l)]}}log(n,r,i){let o={type:n,message:r,data:i};this.dispatchEvent(o)}};function ac(e){if(!e)return;let t=/"([^"]+)"/.exec(e);return t?t[1]:void 0}function oo(e,t){let n=e[t],r;return Array.isArray(n)?r=n[n.length-1]:r=n,r?parseInt(r,10):void 0}function cc(e,t,n){return{method:e,url:t,pathname:"",query:{},params:{},body:n}}0&&(module.exports={FhirRepository,FhirRouter,MemoryRepository,RepositoryMode,Router,createResourceImpl,makeSimpleRequest,processBatch,updateResourceImpl});
55
55
  //# sourceMappingURL=index.cjs.map