@medplum/fhir-router 4.1.2 → 4.1.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/index.cjs +2 -2
- package/dist/cjs/index.cjs.map +4 -4
- package/dist/esm/index.mjs +2 -2
- package/dist/esm/index.mjs.map +4 -4
- package/package.json +4 -4
package/dist/cjs/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";var ao=Object.create;var Dt=Object.defineProperty;var co=Object.getOwnPropertyDescriptor;var uo=Object.getOwnPropertyNames;var po=Object.getPrototypeOf,lo=Object.prototype.hasOwnProperty;var fo=(e,t)=>{for(var n in t)Dt(e,n,{get:t[n],enumerable:!0})},ii=(e,t,n,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of uo(t))!lo.call(e,i)&&i!==n&&Dt(e,i,{get:()=>t[i],enumerable:!(r=co(t,i))||r.enumerable});return e};var oi=(e,t,n)=>(n=e!=null?ao(po(e)):{},ii(t||!e||!e.__esModule?Dt(n,"default",{value:e,enumerable:!0}):n,e)),mo=e=>ii(Dt({},"__esModule",{value:!0}),e);var sc={};fo(sc,{FhirRepository:()=>Rn,FhirRouter:()=>ei,MemoryRepository:()=>Yr,RepositoryMode:()=>_t,Router:()=>wt,createResourceImpl:()=>oo,makeSimpleRequest:()=>oc,updateResourceImpl:()=>so});module.exports=mo(sc);var
|
|
1
|
+
"use strict";var ao=Object.create;var Dt=Object.defineProperty;var co=Object.getOwnPropertyDescriptor;var uo=Object.getOwnPropertyNames;var po=Object.getPrototypeOf,lo=Object.prototype.hasOwnProperty;var fo=(e,t)=>{for(var n in t)Dt(e,n,{get:t[n],enumerable:!0})},ii=(e,t,n,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of uo(t))!lo.call(e,i)&&i!==n&&Dt(e,i,{get:()=>t[i],enumerable:!(r=co(t,i))||r.enumerable});return e};var oi=(e,t,n)=>(n=e!=null?ao(po(e)):{},ii(t||!e||!e.__esModule?Dt(n,"default",{value:e,enumerable:!0}):n,e)),mo=e=>ii(Dt({},"__esModule",{value:!0}),e);var sc={};fo(sc,{FhirRepository:()=>Rn,FhirRouter:()=>ei,MemoryRepository:()=>Yr,RepositoryMode:()=>_t,Router:()=>wt,createResourceImpl:()=>oo,makeSimpleRequest:()=>oc,updateResourceImpl:()=>so});module.exports=mo(sc);var b=require("@medplum/core"),ho=50,yo=8,To=/urn(:|%3A)uuid(:|%3A)[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}/,si="urn:uuid";async function ai(e,t,n,r){return new Ln(n,t,r,e).run()}var Ln=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 b.OperationOutcomeError((0,b.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>ho)throw new b.OperationOutcomeError((0,b.badRequest)("Transaction contains more update operations than allowed"));if(r.requiresStrongTransaction&&n.length>yo)throw new b.OperationOutcomeError((0,b.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 b.OperationOutcomeError((0,b.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]=At((0,b.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]=At(d);continue}throw new b.OperationOutcomeError(d)}let T=this.getRouteForEntry(p)?.data?.interaction;if(!T||!r[T])throw new b.OperationOutcomeError((0,b.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,b.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 b.OperationOutcomeError)return o.outcome;throw o}if(i&&(this.resolvedIdentities[i.placeholder]=i.reference,this.isTransaction())){if(r.has(i.reference))throw new b.OperationOutcomeError((0,b.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 b.OperationOutcomeError(b.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(si))return;let n=t.fullUrl;if(t.request?.ifNoneExist){let r=await this.repo.searchResources((0,b.parseSearchRequest)(t.request.url+"?"+t.request.ifNoneExist));if(r.length===1)return{placeholder:n,reference:(0,b.getReferenceString)(r[0])}}if(t.resource)return t.resource.id=this.repo.generateId(),{placeholder:n,reference:(0,b.getReferenceString)(t.resource)}}async resolveModificationIdentity(t,n){if(!t.fullUrl?.startsWith(si))return;let r=t.fullUrl;if(t.request?.url?.includes("?")){let i=t.request.method,o=(0,b.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 b.OperationOutcomeError((0,b.badRequest)("Cannot provide ID for create by update"));return t.resource.id=this.repo.generateId(),{placeholder:r,reference:(0,b.getReferenceString)(t.resource)}}return;default:throw new b.OperationOutcomeError((0,b.badRequest)(`Conditional ${t.request.method} did not match any resources`,n+".request.url"))}if(a)throw new b.OperationOutcomeError((0,b.badRequest)(`Conditional ${t.request.method} matched multiple resources`,n+".request.url"));let c=(0,b.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 b.OperationOutcomeError((0,b.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=0;for(let c of t.ordering){let p=i[c],l=this.rewriteIdsInObject(p);try{n[c]=await this.processBatchEntry(l)}catch(d){if(this.isTransaction())throw d;s++,n[c]=At((0,b.normalizeOperationOutcome)(d));continue}}let a={type:"batch",bundleType:r,errors:s};return this.router.dispatchEvent(a),{resourceType:"Bundle",type:`${r}-response`,entry:n}}async processBatchEntry(t){let n=this.getRouteForEntry(t);if(!n)throw new b.OperationOutcomeError(b.notFound);let r=this.parseBatchRequest(t,n),[i,o]=await n.handler(r,this.repo,this.router,{batch:!0});if(!(0,b.isOk)(i)&&this.isTransaction())throw new b.OperationOutcomeError(i);return At(i,o)}parseBatchRequest(t,n){let r=t.request,i=Object.create(null);r.ifNoneExist&&(i["if-none-exist"]=r.ifNoneExist),r.ifMatch&&(i["if-match"]=r.ifMatch),r.ifNoneMatch&&(i["if-none-match"]=r.ifNoneMatch),r.ifModifiedSince&&(i["if-modified-since"]=r.ifModifiedSince);let o;return r.method==="PATCH"?o=this.parsePatchBody(t):o=t.resource,{method:r.method,url:n?.query?r.url.slice(0,r.url.indexOf("?")):r.url,pathname:"",params:n?.params??Object.create(null),query:n?.query??Object.create(null),body:o,headers:i}}parsePatchBody(t){let n=t.resource,r;if(n?.resourceType==="Binary"){if(!n.data)throw new b.OperationOutcomeError((0,b.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 b.OperationOutcomeError((0,b.badRequest)("Patch entry must include a Binary or Parameters resource"));if(!Array.isArray(r))throw new b.OperationOutcomeError((0,b.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 b.OperationOutcomeError((0,b.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=To.exec(t)?.[0];if(!n)return t;let r=n.replaceAll("%3A",":"),i=this.resolvedIdentities[r];return i?t.replaceAll(n,i):t}isTransaction(){return this.bundle.type==="transaction"&&!!this.req.config?.transactions}};function At(e,t){return{response:{outcome:e,status:(0,b.getStatus)(e).toString(),location:(0,b.isOk)(e)&&t?.id?(0,b.getReferenceString)(t):void 0},resource:t}}var _=require("@medplum/core");var k=require("@medplum/core"),ro=oi(require("dataloader"));function S(e,t){if(!!!e)throw new Error(t)}function ce(e){return typeof e?.then=="function"}function Y(e){return typeof e=="object"&&e!==null}function V(e,t){if(!!!e)throw new Error(t??"Unexpected invariant triggered.")}var go=/\r\n|[\n\r]/g;function je(e,t){let n=0,r=1;for(let i of e.body.matchAll(go)){if(typeof i.index=="number"||V(!1),i.index>=t)break;n=i.index+i[0].length,r+=1}return{line:r,column:t+1-n}}function wn(e){return Ft(e.source,je(e.source,e.start))}function Ft(e,t){let n=e.locationOffset.column-1,r="".padStart(n)+e.body,i=t.line-1,o=e.locationOffset.line-1,s=t.line+o,a=t.line===1?n:0,c=t.column+a,p=`${e.name}:${s}:${c}
|
|
2
2
|
`,l=r.split(/\r\n|[\n\r]/g),d=l[i];if(d.length>120){let h=Math.floor(c/80),T=c%80,g=[];for(let M=0;M<d.length;M+=80)g.push(d.slice(M,M+80));return p+ci([[`${s} |`,g[0]],...g.slice(1,h+1).map(M=>["|",M]),["|","^".padStart(T)],["|",g[h+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 Eo(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}=Eo(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 h=ui((r=this.nodes)===null||r===void 0?void 0:r.map(g=>g.loc).filter(g=>g!=null));this.source=a??(h==null||(i=h[0])===null||i===void 0?void 0:i.source),this.positions=c??h?.map(g=>g.start),this.locations=c&&a?c.map(g=>je(a,g)):h?.map(g=>je(g.source,g.start));let T=Y(l?.extensions)?l?.extensions:void 0;this.extensions=(o=d??T)!==null&&o!==void 0?o:Object.create(null),Object.defineProperties(this,{message:{writable:!0,enumerable:!0},name:{enumerable:!1},nodes:{enumerable:!1},source:{enumerable:!1},positions:{enumerable:!1},originalError:{enumerable:!1}}),l!=null&&l.stack?Object.defineProperty(this,"stack",{value:l.stack,writable:!0,configurable:!0}):Error.captureStackTrace?Error.captureStackTrace(this,e):Object.defineProperty(this,"stack",{value:Error().stack,writable:!0,configurable:!0})}get[Symbol.toStringTag](){return"GraphQLError"}toString(){let t=this.message;if(this.nodes)for(let n of this.nodes)n.loc&&(t+=`
|
|
4
4
|
|
|
@@ -50,6 +50,6 @@ spurious results.`)}}return!1};var Ye=class{constructor(t,n="GraphQL request",r=
|
|
|
50
50
|
|
|
51
51
|
In some cases, you need to provide options to alter GraphQL's execution behavior in ways field arguments will not suffice, such as conditionally including or skipping a field. Directives provide this by describing additional information to the executor.`,fields:()=>({name:{type:new R(N),resolve:e=>e.name},description:{type:N,resolve:e=>e.description},isRepeatable:{type:new R(q),resolve:e=>e.isRepeatable},locations:{type:new R(new P(new R(Bn))),resolve:e=>e.locations},args:{type:new R(new P(new R(vt))),args:{includeDeprecated:{type:q,defaultValue:!1}},resolve(e,{includeDeprecated:t}){return t?e.args:e.args.filter(n=>n.deprecationReason==null)}}})}),Bn=new Ie({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:I.QUERY,description:"Location adjacent to a query operation."},MUTATION:{value:I.MUTATION,description:"Location adjacent to a mutation operation."},SUBSCRIPTION:{value:I.SUBSCRIPTION,description:"Location adjacent to a subscription operation."},FIELD:{value:I.FIELD,description:"Location adjacent to a field."},FRAGMENT_DEFINITION:{value:I.FRAGMENT_DEFINITION,description:"Location adjacent to a fragment definition."},FRAGMENT_SPREAD:{value:I.FRAGMENT_SPREAD,description:"Location adjacent to a fragment spread."},INLINE_FRAGMENT:{value:I.INLINE_FRAGMENT,description:"Location adjacent to an inline fragment."},VARIABLE_DEFINITION:{value:I.VARIABLE_DEFINITION,description:"Location adjacent to a variable definition."},SCHEMA:{value:I.SCHEMA,description:"Location adjacent to a schema definition."},SCALAR:{value:I.SCALAR,description:"Location adjacent to a scalar definition."},OBJECT:{value:I.OBJECT,description:"Location adjacent to an object type definition."},FIELD_DEFINITION:{value:I.FIELD_DEFINITION,description:"Location adjacent to a field definition."},ARGUMENT_DEFINITION:{value:I.ARGUMENT_DEFINITION,description:"Location adjacent to an argument definition."},INTERFACE:{value:I.INTERFACE,description:"Location adjacent to an interface definition."},UNION:{value:I.UNION,description:"Location adjacent to a union definition."},ENUM:{value:I.ENUM,description:"Location adjacent to an enum definition."},ENUM_VALUE:{value:I.ENUM_VALUE,description:"Location adjacent to an enum value definition."},INPUT_OBJECT:{value:I.INPUT_OBJECT,description:"Location adjacent to an input object type definition."},INPUT_FIELD_DEFINITION:{value:I.INPUT_FIELD_DEFINITION,description:"Location adjacent to an input object field definition."}}}),fe=new H({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(Hn),resolve(e){if(ge(e))return J.SCALAR;if(x(e))return J.OBJECT;if(w(e))return J.INTERFACE;if(X(e))return J.UNION;if(B(e))return J.ENUM;if(A(e))return J.INPUT_OBJECT;if(C(e))return J.LIST;if(O(e))return J.NON_NULL;V(!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(qn)),args:{includeDeprecated:{type:q,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(fe)),resolve(e){if(x(e)||w(e))return e.getInterfaces()}},possibleTypes:{type:new P(new R(fe)),resolve(e,t,n,{schema:r}){if(ie(e))return r.getPossibleTypes(e)}},enumValues:{type:new P(new R(Yn)),args:{includeDeprecated:{type:q,defaultValue:!1}},resolve(e,{includeDeprecated:t}){if(B(e)){let n=e.getValues();return t?n:n.filter(r=>r.deprecationReason==null)}}},inputFields:{type:new P(new R(vt)),args:{includeDeprecated:{type:q,defaultValue:!1}},resolve(e,{includeDeprecated:t}){if(A(e)){let n=Object.values(e.getFields());return t?n:n.filter(r=>r.deprecationReason==null)}}},ofType:{type:fe,resolve:e=>"ofType"in e?e.ofType:void 0},isOneOf:{type:q,resolve:e=>{if(A(e))return e.isOneOf}}})}),qn=new H({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(vt))),args:{includeDeprecated:{type:q,defaultValue:!1}},resolve(e,{includeDeprecated:t}){return t?e.args:e.args.filter(n=>n.deprecationReason==null)}},type:{type:new R(fe),resolve:e=>e.type},isDeprecated:{type:new R(q),resolve:e=>e.deprecationReason!=null},deprecationReason:{type:N,resolve:e=>e.deprecationReason}})}),vt=new H({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(fe),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=tt(n,t);return r?D(r):null}},isDeprecated:{type:new R(q),resolve:e=>e.deprecationReason!=null},deprecationReason:{type:N,resolve:e=>e.deprecationReason}})}),Yn=new H({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(q),resolve:e=>e.deprecationReason!=null},deprecationReason:{type:N,resolve:e=>e.deprecationReason}})}),J;(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"})(J||(J={}));var Hn=new Ie({name:"__TypeKind",description:"An enum describing what kind of type a given `__Type` is.",values:{SCALAR:{value:J.SCALAR,description:"Indicates this type is a scalar."},OBJECT:{value:J.OBJECT,description:"Indicates this type is an object. `fields` and `interfaces` are valid fields."},INTERFACE:{value:J.INTERFACE,description:"Indicates this type is an interface. `fields`, `interfaces`, and `possibleTypes` are valid fields."},UNION:{value:J.UNION,description:"Indicates this type is a union. `possibleTypes` is a valid field."},ENUM:{value:J.ENUM,description:"Indicates this type is an enum. `enumValues` is a valid field."},INPUT_OBJECT:{value:J.INPUT_OBJECT,description:"Indicates this type is an input object. `inputFields` is a valid field."},LIST:{value:J.LIST,description:"Indicates this type is a list. `ofType` is a valid field."},NON_NULL:{value:J.NON_NULL,description:"Indicates this type is a non-null. `ofType` is a valid field."}}}),Ae={name:"__schema",type:new R(Et),description:"Access the current type schema of this server.",args:[],resolve:(e,t,n,{schema:r})=>r,deprecationReason:void 0,extensions:Object.create(null),astNode:void 0},Fe={name:"__type",type:fe,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},ke={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},Wt=Object.freeze([Et,Qn,Bn,fe,qn,vt,Yn,Hn]);function Jn(e){return Wt.some(({name:t})=>e.name===t)}function zn(e){return te(e,Ce)}function Zt(e){if(!zn(e))throw new Error(`Expected ${y(e)} to be a GraphQL schema.`);return e}var Ce=class{constructor(t){var n,r;this.__validationErrors=t.assumeValid===!0?[]:void 0,Y(t)||S(!1,"Must provide configuration object."),!t.types||Array.isArray(t.types)||S(!1,`"types" must be Array if provided but got: ${y(t.types)}.`),!t.directives||Array.isArray(t.directives)||S(!1,`"directives" must be Array if provided but got: ${y(t.directives)}.`),this.description=t.description,this.extensions=re(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:ve;let i=new Set(t.types);if(t.types!=null)for(let o of t.types)i.delete(o),Ne(o,i);this._queryType!=null&&Ne(this._queryType,i),this._mutationType!=null&&Ne(this._mutationType,i),this._subscriptionType!=null&&Ne(this._subscriptionType,i);for(let o of this._directives)if(gt(o))for(let s of o.args)Ne(s.type,i);Ne(Et,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||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 Ne(e,t){let n=z(e);if(!t.has(n)){if(t.add(n),X(n))for(let r of n.getTypes())Ne(r,t);else if(x(n)||w(n)){for(let r of n.getInterfaces())Ne(r,t);for(let r of Object.values(n.getFields())){Ne(r.type,t);for(let i of r.args)Ne(i.type,t)}}else if(A(n))for(let r of Object.values(n.getFields()))Ne(r.type,t)}return t}function Fi(e){if(Zt(e),e.__validationErrors)return e.__validationErrors;let t=new Kn(e);qo(t),Yo(t),Ho(t);let n=t.getErrors();return e.__validationErrors=n,n}function It(e){let t=Fi(e);if(t.length!==0)throw new Error(t.map(n=>n.message).join(`
|
|
52
52
|
|
|
53
|
-
`))}var Kn=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 qo(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=Xn(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=Xn(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=Xn(t,U.SUBSCRIPTION))!==null&&a!==void 0?a:s.astNode)}}function Xn(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 Yo(e){for(let n of e.schema.getDirectives()){if(!gt(n)){e.reportError(`Expected directive but got: ${y(n)}.`,n?.astNode);continue}Me(e,n),n.locations.length===0&&e.reportError(`Directive @${n.name} must include 1 or more locations.`,n.astNode);for(let r of n.args)if(Me(e,r),K(r.type)||e.reportError(`The type of @${n.name}(${r.name}:) must be Input Type but got: ${y(r.type)}.`,r.astNode),Re(r)&&r.deprecationReason!=null){var t;e.reportError(`Required argument @${n.name}(${r.name}:) cannot be deprecated.`,[Wn(r.astNode),(t=r.astNode)===null||t===void 0?void 0:t.type])}}}function Me(e,t){t.name.startsWith("__")&&e.reportError(`Name "${t.name}" must not begin with "__", which is reserved by GraphQL introspection.`,t.astNode)}function Ho(e){let t=es(e),n=e.schema.getTypeMap();for(let r of Object.values(n)){if(!Bt(r)){e.reportError(`Expected GraphQL named type but got: ${y(r)}.`,r.astNode);continue}Jn(r)||Me(e,r),x(r)||w(r)?(wi(e,r),Di(e,r)):X(r)?Xo(e,r):B(r)?Ko(e,r):A(r)&&(Wo(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(Me(e,s),!be(s.type)){var r;e.reportError(`The type of ${t.name}.${s.name} must be Output Type but got: ${y(s.type)}.`,(r=s.astNode)===null||r===void 0?void 0:r.type)}for(let a of s.args){let c=a.name;if(Me(e,a),!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(Re(a)&&a.deprecationReason!=null){var o;e.reportError(`Required argument ${t.name}.${s.name}(${c}:) cannot be deprecated.`,[Wn(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)}.`,Nt(t,r));continue}if(t===r){e.reportError(`Type ${t.name} cannot implement itself because it would create a circular reference.`,Nt(t,r));continue}if(n[r.name]){e.reportError(`Type ${t.name} can only implement ${r.name} once.`,Nt(t,r));continue}n[r.name]=!0,zo(e,t,r),Jo(e,t,r)}}function Jo(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(!Se(e.schema,l.type,c.type)){var i,o;e.reportError(`Interface field ${n.name}.${p} expects type ${y(c.type)} but ${t.name}.${p} is type ${y(l.type)}.`,[(i=c.astNode)===null||i===void 0?void 0:i.type,(o=l.astNode)===null||o===void 0?void 0:o.type])}for(let d of c.args){let h=d.name,T=l.args.find(g=>g.name===h);if(!T){e.reportError(`Interface field argument ${n.name}.${p}(${h}:) expected but ${t.name}.${p} does not provide it.`,[d.astNode,l.astNode]);continue}if(!Ht(d.type,T.type)){var s,a;e.reportError(`Interface field argument ${n.name}.${p}(${h}:) expects type ${y(d.type)} but ${t.name}.${p}(${h}:) is type ${y(T.type)}.`,[(s=d.astNode)===null||s===void 0?void 0:s.type,(a=T.astNode)===null||a===void 0?void 0:a.type])}}for(let d of l.args){let h=d.name;!c.args.find(g=>g.name===h)&&Re(d)&&e.reportError(`Object field ${t.name}.${p} includes required argument ${h} that is missing from the Interface field ${n.name}.${p}.`,[d.astNode,c.astNode])}}}function zo(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}.`,[...Nt(n,i),...Nt(t,n)])}function Xo(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 Ko(e,t){let n=t.getValues();n.length===0&&e.reportError(`Enum type ${t.name} must define one or more values.`,[t.astNode,...t.extensionASTNodes]);for(let r of n)Me(e,r)}function Wo(e,t){let n=Object.values(t.getFields());n.length===0&&e.reportError(`Input Object type ${t.name} must define one or more fields.`,[t.astNode,...t.extensionASTNodes]);for(let o of n){if(Me(e,o),!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(Ze(o)&&o.deprecationReason!=null){var i;e.reportError(`Required input field ${t.name}.${o.name} cannot be deprecated.`,[Wn(o.astNode),(i=o.astNode)===null||i===void 0?void 0:i.type])}t.isOneOf&&Zo(t,o,e)}}function Zo(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 es(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)&&A(a.type.ofType)){let c=a.type.ofType,p=r[c.name];if(n.push(a),p===void 0)i(c);else{let l=n.slice(p),d=l.map(h=>h.name).join(".");e.reportError(`Cannot reference Input Object "${c.name}" within itself through a series of non-null fields: "${d}".`,l.map(h=>h.astNode))}n.pop()}r[o.name]=void 0}}function Nt(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 Wn(e){var t;return e==null||(t=e.directives)===null||t===void 0?void 0:t.find(n=>n.name.value===Kt.name)}function G(e,t){switch(t.kind){case u.LIST_TYPE:{let n=G(e,t.type);return n&&new P(n)}case u.NON_NULL_TYPE:{let n=G(e,t.type);return n&&new R(n)}case u.NAMED_TYPE:return e.getType(t.name.value)}}var nt=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??ts,n&&(K(n)&&this._inputTypeStack.push(n),ue(n)&&this._parentTypeStack.push(n),be(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(be(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?G(n,i):z(this.getType());this._typeStack.push(be(o)?o:void 0);break}case u.VARIABLE_DEFINITION:{let i=G(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=We(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;A(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;B(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 ts(e,t,n){let r=n.name.value;if(r===Ae.name&&e.getQueryType()===t)return Ae;if(r===Fe.name&&e.getQueryType()===t)return Fe;if(r===ke.name&&ue(t))return ke;if(x(t)||w(t))return t.getFields()[r]}function en(e,t){return{enter(...n){let r=n[0];e.enter(r);let i=ze(t,r.kind).enter;if(i){let o=i.apply(t,n);return o!==void 0&&(e.leave(r),at(o)&&e.enter(o)),o}},leave(...n){let r=n[0],i=ze(t,r.kind).leave,o;return i&&(o=i.apply(t,n)),e.leave(r),o}}}function Zn(e){return e.kind===u.OPERATION_DEFINITION||e.kind===u.FRAGMENT_DEFINITION}function er(e){return e.kind===u.SCHEMA_DEFINITION||_e(e)||e.kind===u.DIRECTIVE_DEFINITION}function _e(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 tr(e){return e.kind===u.SCHEMA_EXTENSION||tn(e)}function tn(e){return e.kind===u.SCALAR_TYPE_EXTENSION||e.kind===u.OBJECT_TYPE_EXTENSION||e.kind===u.INTERFACE_TYPE_EXTENSION||e.kind===u.UNION_TYPE_EXTENSION||e.kind===u.ENUM_TYPE_EXTENSION||e.kind===u.INPUT_OBJECT_TYPE_EXTENSION}function nr(e){return{Document(t){for(let n of t.definitions)if(!Zn(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 rr(e){return{Field(t){let n=e.getParentType();if(n&&!e.getFieldDef()){let i=e.getSchema(),o=t.name.value,s=Z("to use an inline fragment on",ns(i,n,o));s===""&&(s=Z(rs(n,o))),e.reportError(new f(`Cannot query field "${o}" on type "${n.name}".`+s,{nodes:t}))}}}}function ns(e,t,n){if(!ie(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:He(s.name,a.name)}).map(s=>s.name)}function rs(e,t){if(x(e)||w(e)){let n=Object.keys(e.getFields());return ne(t,n)}return[]}function ir(e){return{InlineFragment(t){let n=t.typeCondition;if(n){let r=G(e.getSchema(),n);if(r&&!ue(r)){let i=D(n);e.reportError(new f(`Fragment cannot condition on non composite type "${i}".`,{nodes:n}))}}},FragmentDefinition(t){let n=G(e.getSchema(),t.typeCondition);if(n&&!ue(n)){let r=D(t.typeCondition);e.reportError(new f(`Fragment "${t.name.value}" cannot condition on non composite type "${r}".`,{nodes:t.typeCondition}))}}}}function or(e){return{...sr(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=ne(o,s);e.reportError(new f(`Unknown argument "${o}" on field "${i.name}.${r.name}".`+Z(a),{nodes:t}))}}}}function sr(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():ve;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=ne(l,c);e.reportError(new f(`Unknown argument "${l}" on directive "@${a}".`+Z(d),{nodes:p}))}}return!1}}}function nn(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():ve;for(let o of r)t[o.name]=o.locations;let i=e.getDocument().definitions;for(let o of i)o.kind===u.DIRECTIVE_DEFINITION&&(t[o.name.value]=o.locations.map(s=>s.value));return{Directive(o,s,a,c,p){let l=o.name.value,d=t[l];if(!d){e.reportError(new f(`Unknown directive "@${l}".`,{nodes:o}));return}let h=is(p);h&&!d.includes(h)&&e.reportError(new f(`Directive "@${l}" may not be used on ${h}.`,{nodes:o}))}}}function is(e){let t=e[e.length-1];switch("kind"in t||V(!1),t.kind){case u.OPERATION_DEFINITION:return os(t.operation);case u.FIELD:return I.FIELD;case u.FRAGMENT_SPREAD:return I.FRAGMENT_SPREAD;case u.INLINE_FRAGMENT:return I.INLINE_FRAGMENT;case u.FRAGMENT_DEFINITION:return I.FRAGMENT_DEFINITION;case u.VARIABLE_DEFINITION:return I.VARIABLE_DEFINITION;case u.SCHEMA_DEFINITION:case u.SCHEMA_EXTENSION:return I.SCHEMA;case u.SCALAR_TYPE_DEFINITION:case u.SCALAR_TYPE_EXTENSION:return I.SCALAR;case u.OBJECT_TYPE_DEFINITION:case u.OBJECT_TYPE_EXTENSION:return I.OBJECT;case u.FIELD_DEFINITION:return I.FIELD_DEFINITION;case u.INTERFACE_TYPE_DEFINITION:case u.INTERFACE_TYPE_EXTENSION:return I.INTERFACE;case u.UNION_TYPE_DEFINITION:case u.UNION_TYPE_EXTENSION:return I.UNION;case u.ENUM_TYPE_DEFINITION:case u.ENUM_TYPE_EXTENSION:return I.ENUM;case u.ENUM_VALUE_DEFINITION:return I.ENUM_VALUE;case u.INPUT_OBJECT_TYPE_DEFINITION:case u.INPUT_OBJECT_TYPE_EXTENSION:return I.INPUT_OBJECT;case u.INPUT_VALUE_DEFINITION:{let n=e[e.length-3];return"kind"in n||V(!1),n.kind===u.INPUT_OBJECT_TYPE_DEFINITION?I.INPUT_FIELD_DEFINITION:I.ARGUMENT_DEFINITION}default:V(!1,"Unexpected kind: "+y(t.kind))}}function os(e){switch(e){case U.QUERY:return I.QUERY;case U.MUTATION:return I.MUTATION;case U.SUBSCRIPTION:return I.SUBSCRIPTION}}function ar(e){return{FragmentSpread(t){let n=t.name.value;e.getFragment(n)||e.reportError(new f(`Unknown fragment "${n}".`,{nodes:t.name}))}}}function rn(e){let t=e.getSchema(),n=t?t.getTypeMap():Object.create(null),r=Object.create(null);for(let o of e.getDocument().definitions)_e(o)&&(r[o.name.value]=!0);let i=[...Object.keys(n),...Object.keys(r)];return{NamedType(o,s,a,c,p){let l=o.name.value;if(!n[l]&&!r[l]){var d;let h=(d=p[2])!==null&&d!==void 0?d:a,T=h!=null&&ss(h);if(T&&ki.includes(l))return;let g=ne(l,T?ki.concat(i):i);e.reportError(new f(`Unknown type "${l}".`+Z(g),{nodes:o}))}}}}var ki=[...Jt,...Wt].map(e=>e.name);function ss(e){return"kind"in e&&(er(e)||tr(e))}function cr(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 ur(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 as=3;function pr(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>=as))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 lr(e){let t=Object.create(null),n=[],r=Object.create(null);return{OperationDefinition:()=>!1,FragmentDefinition(o){return i(o),!1}};function i(o){if(t[o.name.value])return;let s=o.name.value;t[s]=!0;let a=e.getFragmentSpreads(o.selectionSet);if(a.length!==0){r[s]=n.length;for(let c of a){let p=c.name.value,l=r[p];if(n.push(c),l===void 0){let d=e.getFragment(p);d&&i(d)}else{let d=n.slice(l),h=d.slice(0,-1).map(T=>'"'+T.name.value+'"').join(", ");e.reportError(new f(`Cannot spread fragment "${p}" within itself`+(h!==""?` via ${h}.`:"."),{nodes:d}))}n.pop()}r[s]=void 0}}}function fr(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 dr(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 mr(e){let t=[];return{OperationDefinition:{enter(){t=[]},leave(n){let r=Object.create(null),i=e.getRecursiveVariableUsages(n);for(let{node:o}of i)r[o.name.value]=!0;for(let o of t){let s=o.variable.name.value;r[s]!==!0&&e.reportError(new f(n.name?`Variable "$${s}" is never used in operation "${n.name.value}".`:`Variable "$${s}" is never used.`,{nodes:o}))}}},VariableDefinition(n){t.push(n)}}}function on(e){switch(e.kind){case u.OBJECT:return{...e,fields:cs(e.fields)};case u.LIST:return{...e,values:e.values.map(on)};case u.INT:case u.FLOAT:case u.STRING:case u.BOOLEAN:case u.NULL:case u.ENUM:case u.VARIABLE:return e}}function cs(e){return e.map(t=>({...t,value:on(t.value)})).sort((t,n)=>He(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 gr(e){let t=new un,n=new Tr,r=new Map;return{SelectionSet(i){let o=us(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 us(e,t,n,r,i,o){let s=[],[a,c]=cn(e,t,i,o);if(ls(e,s,t,n,r,a),c.length!==0)for(let p=0;p<c.length;p++){sn(e,s,t,n,r,!1,a,c[p]);for(let l=p+1;l<c.length;l++)an(e,s,t,n,r,!1,c[p],c[l])}return s}function sn(e,t,n,r,i,o,s,a){if(r.has(s,a,o))return;r.add(s,a,o);let c=e.getFragment(a);if(!c)return;let[p,l]=yr(e,n,c);if(s!==p){Er(e,t,n,r,i,o,s,p);for(let d of l)sn(e,t,n,r,i,o,s,d)}}function an(e,t,n,r,i,o,s,a){if(s===a||i.has(s,a,o))return;i.add(s,a,o);let c=e.getFragment(s),p=e.getFragment(a);if(!c||!p)return;let[l,d]=yr(e,n,c),[h,T]=yr(e,n,p);Er(e,t,n,r,i,o,l,h);for(let g of T)an(e,t,n,r,i,o,s,g);for(let g of d)an(e,t,n,r,i,o,g,a)}function ps(e,t,n,r,i,o,s,a,c){let p=[],[l,d]=cn(e,t,o,s),[h,T]=cn(e,t,a,c);Er(e,p,t,n,r,i,l,h);for(let g of T)sn(e,p,t,n,r,i,l,g);for(let g of d)sn(e,p,t,n,r,i,h,g);for(let g of d)for(let M of T)an(e,p,t,n,r,i,g,M);return p}function ls(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 Er(e,t,n,r,i,o,s,a){for(let[c,p]of Object.entries(s)){let l=a[c];if(l)for(let d of p)for(let h of l){let T=Pi(e,n,r,i,o,c,d,h);T&&t.push(T)}}}function Pi(e,t,n,r,i,o,s,a){let[c,p,l]=s,[d,h,T]=a,g=i||c!==d&&x(c)&&x(d);if(!g){let ae=p.name.value,me=h.name.value;if(ae!==me)return[[o,`"${ae}" and "${me}" are different fields`],[p],[h]];if(!fs(p,h))return[[o,"they have differing arguments"],[p],[h]]}let M=l?.type,$=T?.type;if(M&&$&&hr(M,$))return[[o,`they return conflicting types "${y(M)}" and "${y($)}"`],[p],[h]];let oe=p.selectionSet,ot=h.selectionSet;if(oe&&ot){let ae=ps(e,t,n,r,g,z(M),oe,z($),ot);return ds(ae,o,p,h)}}function fs(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 D(on(e))}function hr(e,t){return C(e)?C(t)?hr(e.ofType,t.ofType):!0:C(t)?!0:O(e)?O(t)?hr(e.ofType,t.ofType):!0:O(t)?!0:W(e)||W(t)?e!==t:!1}function cn(e,t,n,r){let i=t.get(r);if(i)return i;let o=Object.create(null),s=Object.create(null);Ui(e,n,r,o,s);let a=[o,Object.keys(s)];return t.set(r,a),a}function yr(e,t,n){let r=t.get(n.selectionSet);if(r)return r;let i=G(e.getSchema(),n.typeCondition);return cn(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?G(e.getSchema(),s):t;Ui(e,a,o.selectionSet,r,i);break}}}function ds(e,t,n,r){if(e.length>0)return[[t,e.map(([i])=>i)],[n,...e.map(([,i])=>i).flat()],[r,...e.map(([,,i])=>i).flat()]]}var un=class{constructor(){this._data=new Map}has(t,n,r){var i;let o=(i=this._data.get(t))===null||i===void 0?void 0:i.get(n);return o===void 0?!1:r?!0:r===o}add(t,n,r){let i=this._data.get(t);i===void 0?this._data.set(t,new Map([[n,r]])):i.set(n,r)}},Tr=class{constructor(){this._orderedPairSet=new un}has(t,n,r){return t<n?this._orderedPairSet.has(t,n,r):this._orderedPairSet.has(n,t,r)}add(t,n,r){t<n?this._orderedPairSet.add(t,n,r):this._orderedPairSet.add(n,t,r)}};function vr(e){return{InlineFragment(t){let n=e.getType(),r=e.getParentType();if(ue(n)&&ue(r)&&!jn(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=ms(e,n),i=e.getParentType();if(r&&i&&!jn(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 ms(e,t){let n=e.getFragment(t);if(n){let r=G(e.getSchema(),n.typeCondition);if(ue(r))return r}}function Nr(e){let t=e.getSchema(),n=Object.create(null);for(let i of e.getDocument().definitions)_e(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=hs[s.kind]:a&&(c=ys(a)),c){if(c!==i.kind){let p=Ts(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=ne(o,p);e.reportError(new f(`Cannot extend type "${o}" because it is not defined.`+Z(l),{nodes:i.name}))}}}var hs={[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 ys(e){if(ge(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(B(e))return u.ENUM_TYPE_EXTENSION;if(A(e))return u.INPUT_OBJECT_TYPE_EXTENSION;V(!1,"Unexpected type: "+y(e))}function Ts(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:V(!1,"Unexpected kind: "+y(e))}}function Ir(e){return{...br(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)&&Re(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 br(e){var t;let n=Object.create(null),r=e.getSchema(),i=(t=r?.getDirectives())!==null&&t!==void 0?t:ve;for(let a of i)n[a.name]=he(a.args.filter(Re),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]=he(c.filter(gs),p=>p.name.value)}return{Directive:{leave(a){let c=a.name.value,p=n[c];if(p){var l;let d=(l=a.arguments)!==null&&l!==void 0?l:[],h=new Set(d.map(T=>T.name.value));for(let[T,g]of Object.entries(p))if(!h.has(T)){let M=Ke(g.type)?y(g.type):D(g.type);e.reportError(new f(`Directive "@${c}" argument "${T}" of type "${M}" is required, but it was not provided.`,{nodes:a}))}}}}}}function gs(e){return e.type.kind===u.NON_NULL_TYPE&&e.defaultValue==null}function Rr(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 pn(e){return e.map(t=>typeof t=="number"?"["+t.toString()+"]":"."+t).join("")}function Pe(e,t,n){return{prev:e,key:t,typename:n}}function ee(e){let t=[],n=e;for(;n;)t.push(n.key),n=n.prev;return t.reverse()}function $i(e,t,n=Es){return bt(e,t,n,void 0)}function Es(e,t,n){let r="Invalid value "+y(t);throw e.length>0&&(r+=` at "value${pn(e)}"`),n.message=r+": "+n.message,n}function bt(e,t,n,r){if(O(t)){if(e!=null)return bt(e,t.ofType,n,r);n(ee(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 et(e)?Array.from(e,(o,s)=>{let a=Pe(r,s,void 0);return bt(o,i,n,a)}):[bt(e,i,n,r)]}if(A(t)){if(!Y(e)){n(ee(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(ee(r),e,new f(`Field "${s.name}" of required type "${c}" was not provided.`))}continue}i[s.name]=bt(a,s.type,n,Pe(r,s.name,t.name))}for(let s of Object.keys(e))if(!o[s]){let a=ne(s,Object.keys(t.getFields()));n(ee(r),e,new f(`Field "${s}" is not defined by type "${t.name}".`+Z(a)))}if(t.isOneOf){let s=Object.keys(i);s.length!==1&&n(ee(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(ee(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(ee(r),e,o):n(ee(r),e,new f(`Expected type "${t.name}". `+o.message,{originalError:o}));return}return i===void 0&&n(ee(r),e,new f(`Expected type "${t.name}".`)),i}V(!1,"Unexpected input type: "+y(t))}function Ue(e,t,n){if(e){if(e.kind===u.VARIABLE){let r=e.name.value;if(n==null||n[r]===void 0)return;let i=n[r];return i===null&&O(t)?void 0:i}if(O(t))return e.kind===u.NULL?void 0:Ue(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=Ue(s,r,n);if(a===void 0)return;o.push(a)}return o}let i=Ue(e,r,n);return i===void 0?void 0:[i]}if(A(t)){if(e.kind!==u.OBJECT)return;let r=Object.create(null),i=he(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=Ue(s.value,o.type,n);if(a===void 0)return;r[o.name]=a}if(t.isOneOf){let o=Object.keys(r);if(o.length!==1||r[o[0]]===null)return}return r}if(W(t)){let r;try{r=t.parseLiteral(e,n)}catch{return}return r===void 0?void 0:r}V(!1,"Unexpected input type: "+y(t))}}function Vi(e,t){return e.kind===u.VARIABLE&&(t==null||t[e.name.value]===void 0)}function Or(e,t,n,r){let i=[],o=r?.maxErrors;try{let s=vs(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 vs(e,t,n,r){let i={};for(let o of t){let s=o.variable.name.value,a=G(e,o.type);if(!K(a)){let p=D(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]=Ue(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 h=`Variable "$${s}" got invalid value `+y(l);p.length>0&&(h+=` at "${s}${pn(p)}"`),r(new f(h+"; "+d.message,{nodes:o,originalError:d}))})}return i}function ln(e,t,n){var r;let i={},o=(r=t.arguments)!==null&&r!==void 0?r:[],s=he(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,h=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}h=n[g]==null}if(h&&O(p))throw new f(`Argument "${c}" of non-null type "${y(p)}" must not be null.`,{nodes:d});let T=Ue(d,p,n);if(T===void 0)throw new f(`Argument "${c}" has invalid value ${D(d)}.`,{nodes:d});i[c]=T}return i}function fn(e,t,n){var r;let i=(r=t.directives)===null||r===void 0?void 0:r.find(o=>o.name.value===e.name);if(i)return ln(e,i,n)}function Gi(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function mn(e,t,n,r,i){let o=new Map;return dn(e,t,n,r,i,o,new Set),o}function Qi(e,t,n,r,i){let o=new Map,s=new Set;for(let a of i)a.selectionSet&&dn(e,t,n,r,a.selectionSet,o,s);return o}function dn(e,t,n,r,i,o,s){for(let a of i.selections)switch(a.kind){case u.FIELD:{if(!Sr(n,a))continue;let c=Ns(a),p=o.get(c);p!==void 0?p.push(a):o.set(c,[a]);break}case u.INLINE_FRAGMENT:{if(!Sr(n,a)||!ji(e,a,r))continue;dn(e,t,n,r,a.selectionSet,o,s);break}case u.FRAGMENT_SPREAD:{let c=a.name.value;if(s.has(c)||!Sr(n,a))continue;s.add(c);let p=t[c];if(!p||!ji(e,p,r))continue;dn(e,t,n,r,p.selectionSet,o,s);break}}}function Sr(e,t){let n=fn(Xt,t,e);if(n?.if===!0)return!1;let r=fn(zt,t,e);return r?.if!==!1}function ji(e,t,n){let r=t.typeCondition;if(!r)return!0;let i=G(e,r);return i===n?!0:ie(i)?e.isSubType(i,n):!1}function Ns(e){return e.alias?e.alias.value:e.name.value}function _r(e){return{OperationDefinition(t){if(t.operation==="subscription"){let n=e.getSchema(),r=n.getSubscriptionType();if(r){let i=t.name?t.name.value:null,o=Object.create(null),s=e.getDocument(),a=Object.create(null);for(let p of s.definitions)p.kind===u.FRAGMENT_DEFINITION&&(a[p.name.value]=p);let c=mn(n,a,o,r,t.selectionSet);if(c.size>1){let d=[...c.values()].slice(1).flat();e.reportError(new f(i!=null?`Subscription "${i}" must select only one top level field.`:"Anonymous Subscription must select only one top level field.",{nodes:d}))}for(let p of c.values())p[0].name.value.startsWith("__")&&e.reportError(new f(i!=null?`Subscription "${i}" must not select an introspection top level field.`:"Anonymous Subscription must not select an introspection top level field.",{nodes:p}))}}}}}function rt(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 xr(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=rt(i,s=>s.name.value);for(let[s,a]of o)a.length>1&&e.reportError(new f(`Argument "${r}(${s}:)" can only be defined once.`,{nodes:a.map(c=>c.name)}));return!1}}function hn(e){return{Field:t,Directive:t};function t(n){var r;let i=(r=n.arguments)!==null&&r!==void 0?r:[],o=rt(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 Lr(e){let t=Object.create(null),n=e.getSchema();return{DirectiveDefinition(r){let i=r.name.value;if(n!=null&&n.getDirective(i)){e.reportError(new f(`Directive "@${i}" already exists in the schema. It cannot be redefined.`,{nodes:r.name}));return}return t[i]?e.reportError(new f(`There can be only one directive named "@${i}".`,{nodes:[t[i],r.name]})):t[i]=r.name,!1}}}function yn(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():ve;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(_e(a)||tn(a)){let p=a.name.value;c=s[p],c===void 0&&(s[p]=c=Object.create(null))}else c=Object.create(null);for(let p of a.directives){let l=p.name.value;t[l]&&(c[l]?e.reportError(new f(`The directive "@${l}" can only be used once at this location.`,{nodes:[c[l],p]})):c[l]=p)}}}}function wr(e){let t=e.getSchema(),n=t?t.getTypeMap():Object.create(null),r=Object.create(null);return{EnumTypeDefinition:i,EnumTypeExtension:i};function i(o){var s;let a=o.name.value;r[a]||(r[a]=Object.create(null));let c=(s=o.values)!==null&&s!==void 0?s:[],p=r[a];for(let l of c){let d=l.name.value,h=n[a];B(h)&&h.getValue(d)?e.reportError(new f(`Enum value "${a}.${d}" already exists in the schema. It cannot also be defined in this type extension.`,{nodes:l.name})):p[d]?e.reportError(new f(`Enum value "${a}.${d}" can only be defined once.`,{nodes:[p[d],l.name]})):p[d]=l.name}return!1}}function Dr(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;Is(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 Is(e,t){return x(e)||w(e)||A(e)?e.getFields()[t]!=null:!1}function Ar(e){let t=Object.create(null);return{OperationDefinition:()=>!1,FragmentDefinition(n){let r=n.name.value;return t[r]?e.reportError(new f(`There can be only one fragment named "${r}".`,{nodes:[t[r],n.name]})):t[r]=n.name,!1}}}function Tn(e){let t=[],n=Object.create(null);return{ObjectValue:{enter(){t.push(n),n=Object.create(null)},leave(){let r=t.pop();r||V(!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 Fr(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 kr(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 Cr(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 Mr(e){return{OperationDefinition(t){var n;let r=(n=t.variableDefinitions)!==null&&n!==void 0?n:[],i=rt(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 Pr(e){let t={};return{OperationDefinition:{enter(){t={}}},VariableDefinition(n){t[n.variable.name.value]=n},ListValue(n){let r=We(e.getParentInputType());if(!C(r))return $e(e,n),!1},ObjectValue(n){let r=z(e.getInputType());if(!A(r))return $e(e,n),!1;let i=he(n.fields,o=>o.name.value);for(let o of Object.values(r.getFields()))if(!i[o.name]&&Ze(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&&bs(e,n,r,i,t)},ObjectField(n){let r=z(e.getParentInputType());if(!e.getInputType()&&A(r)){let o=ne(n.name.value,Object.keys(r.getFields()));e.reportError(new f(`Field "${n.name.value}" is not defined by type "${r.name}".`+Z(o),{nodes:n}))}},NullValue(n){let r=e.getInputType();O(r)&&e.reportError(new f(`Expected value of type "${y(r)}", found ${D(n)}.`,{nodes:n}))},EnumValue:n=>$e(e,n),IntValue:n=>$e(e,n),FloatValue:n=>$e(e,n),StringValue:n=>$e(e,n),BooleanValue:n=>$e(e,n)}}function $e(e,t){let n=e.getInputType();if(!n)return;let r=z(n);if(!W(r)){let i=y(n);e.reportError(new f(`Expected value of type "${i}", found ${D(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 ${D(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 ${D(t)}; `+i.message,{nodes:t,originalError:i}))}}function bs(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 Ur(e){return{VariableDefinition(t){let n=G(e.getSchema(),t.type);if(n!==void 0&&!K(n)){let r=t.variable.name.value,i=D(t.type);e.reportError(new f(`Variable "$${r}" cannot be non-input type "${i}".`,{nodes:t.type}))}}}}function $r(e){let t=Object.create(null);return{OperationDefinition:{enter(){t=Object.create(null)},leave(n){let r=e.getRecursiveVariableUsages(n);for(let{node:i,type:o,defaultValue:s}of r){let a=i.name.value,c=t[a];if(c&&o){let p=e.getSchema(),l=G(p,c.type);if(l&&!Rs(p,l,c.defaultValue,o,s)){let d=y(l),h=y(o);e.reportError(new f(`Variable "$${a}" of type "${d}" used in position expecting type "${h}".`,{nodes:[c,i]}))}}}}},VariableDefinition(n){t[n.variable.name.value]=n}}}function Rs(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 Se(e,t,a)}return Se(e,t,r)}var Vr=Object.freeze([pr]),it=Object.freeze([nr,Fr,cr,_r,rn,ir,Ur,Rr,rr,Ar,ar,dr,vr,lr,Mr,fr,mr,nn,yn,or,hn,Pr,Ir,$r,gr,Tn,...Vr]),Os=Object.freeze([ur,kr,Cr,wr,Dr,xr,Lr,rn,nn,yn,Nr,sr,hn,Tn,br]);var Gr=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 Rt=class extends Gr{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 nt(this._schema);Le(t,en(i,{VariableDefinition:()=>!1,Variable(o){r.push({node:o,type:i.getInputType(),defaultValue:i.getDefaultValue()})}})),n=r,this._variableUsages.set(t,n)}return n}getRecursiveVariableUsages(t){let n=this._recursiveVariableUsages.get(t);if(!n){n=this.getVariableUsages(t);for(let r of this.getRecursivelyReferencedFragments(t))n=n.concat(this.getVariableUsages(r));this._recursiveVariableUsages.set(t,n)}return n}getType(){return this._typeInfo.getType()}getParentType(){return this._typeInfo.getParentType()}getInputType(){return this._typeInfo.getInputType()}getParentInputType(){return this._typeInfo.getParentInputType()}getFieldDef(){return this._typeInfo.getFieldDef()}getDirective(){return this._typeInfo.getDirective()}getArgument(){return this._typeInfo.getArgument()}getEnumValue(){return this._typeInfo.getEnumValue()}};function gn(e,t,n=it,r,i=new nt(e)){var o;let s=(o=r?.maxErrors)!==null&&o!==void 0?o:100;t||S(!1,"Must provide document."),It(e);let a=Object.freeze({}),c=[],p=new Rt(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=Pn(n.map(d=>d(p)));try{Le(t,en(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 jr(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 Qr(e)}var Qr=class extends Error{constructor(t){super("Unexpected error value: "+y(t)),this.name="NonErrorThrown",this.thrownValue=t}};function Ot(e,t,n){var r;let i=Yi(e);return Ss(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 Ss(e){return Array.isArray(e.path)}var _s=Bi((e,t,n)=>Qi(e.schema,e.fragments,e.variableValues,t,n));function bn(e){arguments.length<2||S(!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;xs(t,n,r);let o=Ls(e);if(!("schema"in o))return{errors:o};try{let{operation:s}=o,a=ws(o,s,i);return ce(a)?a.then(c=>En(c,o.errors),c=>(o.errors.push(c),En(null,o.errors))):En(a,o.errors)}catch(s){return o.errors.push(s),En(null,o.errors)}}function En(e,t){return t.length===0?{data:e}:{errors:t,data:e}}function xs(e,t,n){t||S(!1,"Must provide document."),It(e),n==null||Y(n)||S(!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 Ls(e){var t,n;let{schema:r,document:i,rootValue:o,contextValue:s,variableValues:a,operationName:c,fieldResolver:p,typeResolver:l,subscribeFieldResolver:d}=e,h,T=Object.create(null);for(let $ of i.definitions)switch($.kind){case u.OPERATION_DEFINITION:if(c==null){if(h!==void 0)return[new f("Must provide operation name if query contains multiple operations.")];h=$}else((t=$.name)===null||t===void 0?void 0:t.value)===c&&(h=$);break;case u.FRAGMENT_DEFINITION:T[$.name.value]=$;break;default:}if(!h)return c!=null?[new f(`Unknown operation named "${c}".`)]:[new f("Must provide an operation.")];let g=(n=h.variableDefinitions)!==null&&n!==void 0?n:[],M=Or(r,g,a??{},{maxErrors:50});return M.errors?M.errors:{schema:r,fragments:T,rootValue:o,contextValue:s,operation:h,variableValues:M.coerced,fieldResolver:p??In,typeResolver:l??qr,subscribeFieldResolver:d??In,errors:[]}}function ws(e,t,n){let r=e.schema.getRootType(t.operation);if(r==null)throw new f(`Schema is not configured to execute ${t.operation} operation.`,{nodes:t});let i=mn(e.schema,e.fragments,e.variableValues,r,t.selectionSet),o=void 0;switch(t.operation){case U.QUERY:return vn(e,r,n,o,i);case U.MUTATION:return Ds(e,r,n,o,i);case U.SUBSCRIPTION:return vn(e,r,n,o,i)}}function Ds(e,t,n,r,i){return qi(i.entries(),(o,[s,a])=>{let c=Pe(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 vn(e,t,n,r,i){let o=Object.create(null),s=!1;try{for(let[a,c]of i.entries()){let p=Pe(r,a,t.name),l=zi(e,t,n,c,p);l!==void 0&&(o[a]=l,ce(l)&&(s=!0))}}catch(a){if(s)return jr(o).finally(()=>{throw a});throw a}return s?jr(o):o}function zi(e,t,n,r,i){var o;let s=Ms(e.schema,t,r[0]);if(!s)return;let a=s.type,c=(o=s.resolve)!==null&&o!==void 0?o:e.fieldResolver,p=As(e,s,r,t,i);try{let l=ln(s,r[0],e.variableValues),d=e.contextValue,h=c(n,l,d,p),T;return ce(h)?T=h.then(g=>St(e,a,r,p,i,g)):T=St(e,a,r,p,i,h),ce(T)?T.then(void 0,g=>{let M=Ot(g,r,ee(i));return Nn(M,a,e)}):T}catch(l){let d=Ot(l,r,ee(i));return Nn(d,a,e)}}function As(e,t,n,r,i){return{fieldName:t.name,fieldNodes:n,returnType:t.type,parentType:r,path:i,schema:e.schema,fragments:e.fragments,rootValue:e.rootValue,operation:e.operation,variableValues:e.variableValues}}function Nn(e,t,n){if(O(t))throw e;return n.errors.push(e),null}function St(e,t,n,r,i,o){if(o instanceof Error)throw o;if(O(t)){let s=St(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 Fs(e,t,n,r,i,o);if(W(t))return ks(t,o);if(ie(t))return Cs(e,t,n,r,i,o);if(x(t))return Br(e,t,n,r,i,o);V(!1,"Cannot complete value of unexpected output type: "+y(t))}function Fs(e,t,n,r,i,o){if(!et(o))throw new f(`Expected Iterable, but did not find one for field "${r.parentType.name}.${r.fieldName}".`);let s=t.ofType,a=!1,c=Array.from(o,(p,l)=>{let d=Pe(i,l,void 0);try{let h;return ce(p)?h=p.then(T=>St(e,s,n,r,d,T)):h=St(e,s,n,r,d,p),ce(h)?(a=!0,h.then(void 0,T=>{let g=Ot(T,n,ee(d));return Nn(g,s,e)})):h}catch(h){let T=Ot(h,n,ee(d));return Nn(T,s,e)}});return a?Promise.all(c):c}function ks(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 Cs(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=>Br(e,Hi(l,e,t,n,r,o),n,r,i,o)):Br(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 Br(e,t,n,r,i,o){let s=_s(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 vn(e,t,o,i,s)});if(!a)throw Ji(t,o,n)}return vn(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 qr=function(e,t,n,r){if(Y(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})},In=function(e,t,n,r){if(Y(e)||typeof e=="function"){let i=e[r.fieldName];return typeof i=="function"?e[r.fieldName](t,n,r):i}};function Ms(e,t,n){let r=n.name.value;return r===Ae.name&&e.getQueryType()===t?Ae:r===Fe.name&&e.getQueryType()===t?Fe:r===ke.name?ke:t.getFields()[r]}var E=require("@medplum/core"),Xi=require("rfc6902"),_t={READER:"reader",WRITER:"writer"},Rn=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 o=i[0];if(!r?.assignedId&&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:i[0],outcome:E.allOk}}else if(i.length>1)throw new E.OperationOutcomeError(E.multipleMatches);return t=await this.createResource(t,r),{resource:t,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 t=await this.createResource(t,r),{resource:t,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 t.id=o.id,t=await this.updateResource(t,r),{resource:t,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)})}},Yr=class extends Rn{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(`
|
|
53
|
+
`))}var Kn=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 qo(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=Xn(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=Xn(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=Xn(t,U.SUBSCRIPTION))!==null&&a!==void 0?a:s.astNode)}}function Xn(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 Yo(e){for(let n of e.schema.getDirectives()){if(!gt(n)){e.reportError(`Expected directive but got: ${y(n)}.`,n?.astNode);continue}Me(e,n),n.locations.length===0&&e.reportError(`Directive @${n.name} must include 1 or more locations.`,n.astNode);for(let r of n.args)if(Me(e,r),K(r.type)||e.reportError(`The type of @${n.name}(${r.name}:) must be Input Type but got: ${y(r.type)}.`,r.astNode),Re(r)&&r.deprecationReason!=null){var t;e.reportError(`Required argument @${n.name}(${r.name}:) cannot be deprecated.`,[Wn(r.astNode),(t=r.astNode)===null||t===void 0?void 0:t.type])}}}function Me(e,t){t.name.startsWith("__")&&e.reportError(`Name "${t.name}" must not begin with "__", which is reserved by GraphQL introspection.`,t.astNode)}function Ho(e){let t=es(e),n=e.schema.getTypeMap();for(let r of Object.values(n)){if(!Bt(r)){e.reportError(`Expected GraphQL named type but got: ${y(r)}.`,r.astNode);continue}Jn(r)||Me(e,r),x(r)||w(r)?(wi(e,r),Di(e,r)):X(r)?Xo(e,r):B(r)?Ko(e,r):A(r)&&(Wo(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(Me(e,s),!be(s.type)){var r;e.reportError(`The type of ${t.name}.${s.name} must be Output Type but got: ${y(s.type)}.`,(r=s.astNode)===null||r===void 0?void 0:r.type)}for(let a of s.args){let c=a.name;if(Me(e,a),!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(Re(a)&&a.deprecationReason!=null){var o;e.reportError(`Required argument ${t.name}.${s.name}(${c}:) cannot be deprecated.`,[Wn(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)}.`,Nt(t,r));continue}if(t===r){e.reportError(`Type ${t.name} cannot implement itself because it would create a circular reference.`,Nt(t,r));continue}if(n[r.name]){e.reportError(`Type ${t.name} can only implement ${r.name} once.`,Nt(t,r));continue}n[r.name]=!0,zo(e,t,r),Jo(e,t,r)}}function Jo(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(!Se(e.schema,l.type,c.type)){var i,o;e.reportError(`Interface field ${n.name}.${p} expects type ${y(c.type)} but ${t.name}.${p} is type ${y(l.type)}.`,[(i=c.astNode)===null||i===void 0?void 0:i.type,(o=l.astNode)===null||o===void 0?void 0:o.type])}for(let d of c.args){let h=d.name,T=l.args.find(g=>g.name===h);if(!T){e.reportError(`Interface field argument ${n.name}.${p}(${h}:) expected but ${t.name}.${p} does not provide it.`,[d.astNode,l.astNode]);continue}if(!Ht(d.type,T.type)){var s,a;e.reportError(`Interface field argument ${n.name}.${p}(${h}:) expects type ${y(d.type)} but ${t.name}.${p}(${h}:) is type ${y(T.type)}.`,[(s=d.astNode)===null||s===void 0?void 0:s.type,(a=T.astNode)===null||a===void 0?void 0:a.type])}}for(let d of l.args){let h=d.name;!c.args.find(g=>g.name===h)&&Re(d)&&e.reportError(`Object field ${t.name}.${p} includes required argument ${h} that is missing from the Interface field ${n.name}.${p}.`,[d.astNode,c.astNode])}}}function zo(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}.`,[...Nt(n,i),...Nt(t,n)])}function Xo(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 Ko(e,t){let n=t.getValues();n.length===0&&e.reportError(`Enum type ${t.name} must define one or more values.`,[t.astNode,...t.extensionASTNodes]);for(let r of n)Me(e,r)}function Wo(e,t){let n=Object.values(t.getFields());n.length===0&&e.reportError(`Input Object type ${t.name} must define one or more fields.`,[t.astNode,...t.extensionASTNodes]);for(let o of n){if(Me(e,o),!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(Ze(o)&&o.deprecationReason!=null){var i;e.reportError(`Required input field ${t.name}.${o.name} cannot be deprecated.`,[Wn(o.astNode),(i=o.astNode)===null||i===void 0?void 0:i.type])}t.isOneOf&&Zo(t,o,e)}}function Zo(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 es(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)&&A(a.type.ofType)){let c=a.type.ofType,p=r[c.name];if(n.push(a),p===void 0)i(c);else{let l=n.slice(p),d=l.map(h=>h.name).join(".");e.reportError(`Cannot reference Input Object "${c.name}" within itself through a series of non-null fields: "${d}".`,l.map(h=>h.astNode))}n.pop()}r[o.name]=void 0}}function Nt(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 Wn(e){var t;return e==null||(t=e.directives)===null||t===void 0?void 0:t.find(n=>n.name.value===Kt.name)}function G(e,t){switch(t.kind){case u.LIST_TYPE:{let n=G(e,t.type);return n&&new P(n)}case u.NON_NULL_TYPE:{let n=G(e,t.type);return n&&new R(n)}case u.NAMED_TYPE:return e.getType(t.name.value)}}var nt=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??ts,n&&(K(n)&&this._inputTypeStack.push(n),ue(n)&&this._parentTypeStack.push(n),be(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(be(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?G(n,i):z(this.getType());this._typeStack.push(be(o)?o:void 0);break}case u.VARIABLE_DEFINITION:{let i=G(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=We(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;A(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;B(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 ts(e,t,n){let r=n.name.value;if(r===Ae.name&&e.getQueryType()===t)return Ae;if(r===Fe.name&&e.getQueryType()===t)return Fe;if(r===ke.name&&ue(t))return ke;if(x(t)||w(t))return t.getFields()[r]}function en(e,t){return{enter(...n){let r=n[0];e.enter(r);let i=ze(t,r.kind).enter;if(i){let o=i.apply(t,n);return o!==void 0&&(e.leave(r),at(o)&&e.enter(o)),o}},leave(...n){let r=n[0],i=ze(t,r.kind).leave,o;return i&&(o=i.apply(t,n)),e.leave(r),o}}}function Zn(e){return e.kind===u.OPERATION_DEFINITION||e.kind===u.FRAGMENT_DEFINITION}function er(e){return e.kind===u.SCHEMA_DEFINITION||_e(e)||e.kind===u.DIRECTIVE_DEFINITION}function _e(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 tr(e){return e.kind===u.SCHEMA_EXTENSION||tn(e)}function tn(e){return e.kind===u.SCALAR_TYPE_EXTENSION||e.kind===u.OBJECT_TYPE_EXTENSION||e.kind===u.INTERFACE_TYPE_EXTENSION||e.kind===u.UNION_TYPE_EXTENSION||e.kind===u.ENUM_TYPE_EXTENSION||e.kind===u.INPUT_OBJECT_TYPE_EXTENSION}function nr(e){return{Document(t){for(let n of t.definitions)if(!Zn(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 rr(e){return{Field(t){let n=e.getParentType();if(n&&!e.getFieldDef()){let i=e.getSchema(),o=t.name.value,s=Z("to use an inline fragment on",ns(i,n,o));s===""&&(s=Z(rs(n,o))),e.reportError(new f(`Cannot query field "${o}" on type "${n.name}".`+s,{nodes:t}))}}}}function ns(e,t,n){if(!ie(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:He(s.name,a.name)}).map(s=>s.name)}function rs(e,t){if(x(e)||w(e)){let n=Object.keys(e.getFields());return ne(t,n)}return[]}function ir(e){return{InlineFragment(t){let n=t.typeCondition;if(n){let r=G(e.getSchema(),n);if(r&&!ue(r)){let i=D(n);e.reportError(new f(`Fragment cannot condition on non composite type "${i}".`,{nodes:n}))}}},FragmentDefinition(t){let n=G(e.getSchema(),t.typeCondition);if(n&&!ue(n)){let r=D(t.typeCondition);e.reportError(new f(`Fragment "${t.name.value}" cannot condition on non composite type "${r}".`,{nodes:t.typeCondition}))}}}}function or(e){return{...sr(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=ne(o,s);e.reportError(new f(`Unknown argument "${o}" on field "${i.name}.${r.name}".`+Z(a),{nodes:t}))}}}}function sr(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():ve;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=ne(l,c);e.reportError(new f(`Unknown argument "${l}" on directive "@${a}".`+Z(d),{nodes:p}))}}return!1}}}function nn(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():ve;for(let o of r)t[o.name]=o.locations;let i=e.getDocument().definitions;for(let o of i)o.kind===u.DIRECTIVE_DEFINITION&&(t[o.name.value]=o.locations.map(s=>s.value));return{Directive(o,s,a,c,p){let l=o.name.value,d=t[l];if(!d){e.reportError(new f(`Unknown directive "@${l}".`,{nodes:o}));return}let h=is(p);h&&!d.includes(h)&&e.reportError(new f(`Directive "@${l}" may not be used on ${h}.`,{nodes:o}))}}}function is(e){let t=e[e.length-1];switch("kind"in t||V(!1),t.kind){case u.OPERATION_DEFINITION:return os(t.operation);case u.FIELD:return I.FIELD;case u.FRAGMENT_SPREAD:return I.FRAGMENT_SPREAD;case u.INLINE_FRAGMENT:return I.INLINE_FRAGMENT;case u.FRAGMENT_DEFINITION:return I.FRAGMENT_DEFINITION;case u.VARIABLE_DEFINITION:return I.VARIABLE_DEFINITION;case u.SCHEMA_DEFINITION:case u.SCHEMA_EXTENSION:return I.SCHEMA;case u.SCALAR_TYPE_DEFINITION:case u.SCALAR_TYPE_EXTENSION:return I.SCALAR;case u.OBJECT_TYPE_DEFINITION:case u.OBJECT_TYPE_EXTENSION:return I.OBJECT;case u.FIELD_DEFINITION:return I.FIELD_DEFINITION;case u.INTERFACE_TYPE_DEFINITION:case u.INTERFACE_TYPE_EXTENSION:return I.INTERFACE;case u.UNION_TYPE_DEFINITION:case u.UNION_TYPE_EXTENSION:return I.UNION;case u.ENUM_TYPE_DEFINITION:case u.ENUM_TYPE_EXTENSION:return I.ENUM;case u.ENUM_VALUE_DEFINITION:return I.ENUM_VALUE;case u.INPUT_OBJECT_TYPE_DEFINITION:case u.INPUT_OBJECT_TYPE_EXTENSION:return I.INPUT_OBJECT;case u.INPUT_VALUE_DEFINITION:{let n=e[e.length-3];return"kind"in n||V(!1),n.kind===u.INPUT_OBJECT_TYPE_DEFINITION?I.INPUT_FIELD_DEFINITION:I.ARGUMENT_DEFINITION}default:V(!1,"Unexpected kind: "+y(t.kind))}}function os(e){switch(e){case U.QUERY:return I.QUERY;case U.MUTATION:return I.MUTATION;case U.SUBSCRIPTION:return I.SUBSCRIPTION}}function ar(e){return{FragmentSpread(t){let n=t.name.value;e.getFragment(n)||e.reportError(new f(`Unknown fragment "${n}".`,{nodes:t.name}))}}}function rn(e){let t=e.getSchema(),n=t?t.getTypeMap():Object.create(null),r=Object.create(null);for(let o of e.getDocument().definitions)_e(o)&&(r[o.name.value]=!0);let i=[...Object.keys(n),...Object.keys(r)];return{NamedType(o,s,a,c,p){let l=o.name.value;if(!n[l]&&!r[l]){var d;let h=(d=p[2])!==null&&d!==void 0?d:a,T=h!=null&&ss(h);if(T&&ki.includes(l))return;let g=ne(l,T?ki.concat(i):i);e.reportError(new f(`Unknown type "${l}".`+Z(g),{nodes:o}))}}}}var ki=[...Jt,...Wt].map(e=>e.name);function ss(e){return"kind"in e&&(er(e)||tr(e))}function cr(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 ur(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 as=3;function pr(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>=as))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 lr(e){let t=Object.create(null),n=[],r=Object.create(null);return{OperationDefinition:()=>!1,FragmentDefinition(o){return i(o),!1}};function i(o){if(t[o.name.value])return;let s=o.name.value;t[s]=!0;let a=e.getFragmentSpreads(o.selectionSet);if(a.length!==0){r[s]=n.length;for(let c of a){let p=c.name.value,l=r[p];if(n.push(c),l===void 0){let d=e.getFragment(p);d&&i(d)}else{let d=n.slice(l),h=d.slice(0,-1).map(T=>'"'+T.name.value+'"').join(", ");e.reportError(new f(`Cannot spread fragment "${p}" within itself`+(h!==""?` via ${h}.`:"."),{nodes:d}))}n.pop()}r[s]=void 0}}}function fr(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 dr(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 mr(e){let t=[];return{OperationDefinition:{enter(){t=[]},leave(n){let r=Object.create(null),i=e.getRecursiveVariableUsages(n);for(let{node:o}of i)r[o.name.value]=!0;for(let o of t){let s=o.variable.name.value;r[s]!==!0&&e.reportError(new f(n.name?`Variable "$${s}" is never used in operation "${n.name.value}".`:`Variable "$${s}" is never used.`,{nodes:o}))}}},VariableDefinition(n){t.push(n)}}}function on(e){switch(e.kind){case u.OBJECT:return{...e,fields:cs(e.fields)};case u.LIST:return{...e,values:e.values.map(on)};case u.INT:case u.FLOAT:case u.STRING:case u.BOOLEAN:case u.NULL:case u.ENUM:case u.VARIABLE:return e}}function cs(e){return e.map(t=>({...t,value:on(t.value)})).sort((t,n)=>He(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 gr(e){let t=new un,n=new Tr,r=new Map;return{SelectionSet(i){let o=us(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 us(e,t,n,r,i,o){let s=[],[a,c]=cn(e,t,i,o);if(ls(e,s,t,n,r,a),c.length!==0)for(let p=0;p<c.length;p++){sn(e,s,t,n,r,!1,a,c[p]);for(let l=p+1;l<c.length;l++)an(e,s,t,n,r,!1,c[p],c[l])}return s}function sn(e,t,n,r,i,o,s,a){if(r.has(s,a,o))return;r.add(s,a,o);let c=e.getFragment(a);if(!c)return;let[p,l]=yr(e,n,c);if(s!==p){Er(e,t,n,r,i,o,s,p);for(let d of l)sn(e,t,n,r,i,o,s,d)}}function an(e,t,n,r,i,o,s,a){if(s===a||i.has(s,a,o))return;i.add(s,a,o);let c=e.getFragment(s),p=e.getFragment(a);if(!c||!p)return;let[l,d]=yr(e,n,c),[h,T]=yr(e,n,p);Er(e,t,n,r,i,o,l,h);for(let g of T)an(e,t,n,r,i,o,s,g);for(let g of d)an(e,t,n,r,i,o,g,a)}function ps(e,t,n,r,i,o,s,a,c){let p=[],[l,d]=cn(e,t,o,s),[h,T]=cn(e,t,a,c);Er(e,p,t,n,r,i,l,h);for(let g of T)sn(e,p,t,n,r,i,l,g);for(let g of d)sn(e,p,t,n,r,i,h,g);for(let g of d)for(let M of T)an(e,p,t,n,r,i,g,M);return p}function ls(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 Er(e,t,n,r,i,o,s,a){for(let[c,p]of Object.entries(s)){let l=a[c];if(l)for(let d of p)for(let h of l){let T=Pi(e,n,r,i,o,c,d,h);T&&t.push(T)}}}function Pi(e,t,n,r,i,o,s,a){let[c,p,l]=s,[d,h,T]=a,g=i||c!==d&&x(c)&&x(d);if(!g){let ae=p.name.value,me=h.name.value;if(ae!==me)return[[o,`"${ae}" and "${me}" are different fields`],[p],[h]];if(!fs(p,h))return[[o,"they have differing arguments"],[p],[h]]}let M=l?.type,$=T?.type;if(M&&$&&hr(M,$))return[[o,`they return conflicting types "${y(M)}" and "${y($)}"`],[p],[h]];let oe=p.selectionSet,ot=h.selectionSet;if(oe&&ot){let ae=ps(e,t,n,r,g,z(M),oe,z($),ot);return ds(ae,o,p,h)}}function fs(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 D(on(e))}function hr(e,t){return C(e)?C(t)?hr(e.ofType,t.ofType):!0:C(t)?!0:O(e)?O(t)?hr(e.ofType,t.ofType):!0:O(t)?!0:W(e)||W(t)?e!==t:!1}function cn(e,t,n,r){let i=t.get(r);if(i)return i;let o=Object.create(null),s=Object.create(null);Ui(e,n,r,o,s);let a=[o,Object.keys(s)];return t.set(r,a),a}function yr(e,t,n){let r=t.get(n.selectionSet);if(r)return r;let i=G(e.getSchema(),n.typeCondition);return cn(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?G(e.getSchema(),s):t;Ui(e,a,o.selectionSet,r,i);break}}}function ds(e,t,n,r){if(e.length>0)return[[t,e.map(([i])=>i)],[n,...e.map(([,i])=>i).flat()],[r,...e.map(([,,i])=>i).flat()]]}var un=class{constructor(){this._data=new Map}has(t,n,r){var i;let o=(i=this._data.get(t))===null||i===void 0?void 0:i.get(n);return o===void 0?!1:r?!0:r===o}add(t,n,r){let i=this._data.get(t);i===void 0?this._data.set(t,new Map([[n,r]])):i.set(n,r)}},Tr=class{constructor(){this._orderedPairSet=new un}has(t,n,r){return t<n?this._orderedPairSet.has(t,n,r):this._orderedPairSet.has(n,t,r)}add(t,n,r){t<n?this._orderedPairSet.add(t,n,r):this._orderedPairSet.add(n,t,r)}};function vr(e){return{InlineFragment(t){let n=e.getType(),r=e.getParentType();if(ue(n)&&ue(r)&&!jn(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=ms(e,n),i=e.getParentType();if(r&&i&&!jn(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 ms(e,t){let n=e.getFragment(t);if(n){let r=G(e.getSchema(),n.typeCondition);if(ue(r))return r}}function Nr(e){let t=e.getSchema(),n=Object.create(null);for(let i of e.getDocument().definitions)_e(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=hs[s.kind]:a&&(c=ys(a)),c){if(c!==i.kind){let p=Ts(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=ne(o,p);e.reportError(new f(`Cannot extend type "${o}" because it is not defined.`+Z(l),{nodes:i.name}))}}}var hs={[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 ys(e){if(ge(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(B(e))return u.ENUM_TYPE_EXTENSION;if(A(e))return u.INPUT_OBJECT_TYPE_EXTENSION;V(!1,"Unexpected type: "+y(e))}function Ts(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:V(!1,"Unexpected kind: "+y(e))}}function Ir(e){return{...br(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)&&Re(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 br(e){var t;let n=Object.create(null),r=e.getSchema(),i=(t=r?.getDirectives())!==null&&t!==void 0?t:ve;for(let a of i)n[a.name]=he(a.args.filter(Re),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]=he(c.filter(gs),p=>p.name.value)}return{Directive:{leave(a){let c=a.name.value,p=n[c];if(p){var l;let d=(l=a.arguments)!==null&&l!==void 0?l:[],h=new Set(d.map(T=>T.name.value));for(let[T,g]of Object.entries(p))if(!h.has(T)){let M=Ke(g.type)?y(g.type):D(g.type);e.reportError(new f(`Directive "@${c}" argument "${T}" of type "${M}" is required, but it was not provided.`,{nodes:a}))}}}}}}function gs(e){return e.type.kind===u.NON_NULL_TYPE&&e.defaultValue==null}function Rr(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 pn(e){return e.map(t=>typeof t=="number"?"["+t.toString()+"]":"."+t).join("")}function Pe(e,t,n){return{prev:e,key:t,typename:n}}function ee(e){let t=[],n=e;for(;n;)t.push(n.key),n=n.prev;return t.reverse()}function $i(e,t,n=Es){return bt(e,t,n,void 0)}function Es(e,t,n){let r="Invalid value "+y(t);throw e.length>0&&(r+=` at "value${pn(e)}"`),n.message=r+": "+n.message,n}function bt(e,t,n,r){if(O(t)){if(e!=null)return bt(e,t.ofType,n,r);n(ee(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 et(e)?Array.from(e,(o,s)=>{let a=Pe(r,s,void 0);return bt(o,i,n,a)}):[bt(e,i,n,r)]}if(A(t)){if(!Y(e)){n(ee(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(ee(r),e,new f(`Field "${s.name}" of required type "${c}" was not provided.`))}continue}i[s.name]=bt(a,s.type,n,Pe(r,s.name,t.name))}for(let s of Object.keys(e))if(!o[s]){let a=ne(s,Object.keys(t.getFields()));n(ee(r),e,new f(`Field "${s}" is not defined by type "${t.name}".`+Z(a)))}if(t.isOneOf){let s=Object.keys(i);s.length!==1&&n(ee(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(ee(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(ee(r),e,o):n(ee(r),e,new f(`Expected type "${t.name}". `+o.message,{originalError:o}));return}return i===void 0&&n(ee(r),e,new f(`Expected type "${t.name}".`)),i}V(!1,"Unexpected input type: "+y(t))}function Ue(e,t,n){if(e){if(e.kind===u.VARIABLE){let r=e.name.value;if(n==null||n[r]===void 0)return;let i=n[r];return i===null&&O(t)?void 0:i}if(O(t))return e.kind===u.NULL?void 0:Ue(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=Ue(s,r,n);if(a===void 0)return;o.push(a)}return o}let i=Ue(e,r,n);return i===void 0?void 0:[i]}if(A(t)){if(e.kind!==u.OBJECT)return;let r=Object.create(null),i=he(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=Ue(s.value,o.type,n);if(a===void 0)return;r[o.name]=a}if(t.isOneOf){let o=Object.keys(r);if(o.length!==1||r[o[0]]===null)return}return r}if(W(t)){let r;try{r=t.parseLiteral(e,n)}catch{return}return r===void 0?void 0:r}V(!1,"Unexpected input type: "+y(t))}}function Vi(e,t){return e.kind===u.VARIABLE&&(t==null||t[e.name.value]===void 0)}function Or(e,t,n,r){let i=[],o=r?.maxErrors;try{let s=vs(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 vs(e,t,n,r){let i={};for(let o of t){let s=o.variable.name.value,a=G(e,o.type);if(!K(a)){let p=D(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]=Ue(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 h=`Variable "$${s}" got invalid value `+y(l);p.length>0&&(h+=` at "${s}${pn(p)}"`),r(new f(h+"; "+d.message,{nodes:o,originalError:d}))})}return i}function ln(e,t,n){var r;let i={},o=(r=t.arguments)!==null&&r!==void 0?r:[],s=he(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,h=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}h=n[g]==null}if(h&&O(p))throw new f(`Argument "${c}" of non-null type "${y(p)}" must not be null.`,{nodes:d});let T=Ue(d,p,n);if(T===void 0)throw new f(`Argument "${c}" has invalid value ${D(d)}.`,{nodes:d});i[c]=T}return i}function fn(e,t,n){var r;let i=(r=t.directives)===null||r===void 0?void 0:r.find(o=>o.name.value===e.name);if(i)return ln(e,i,n)}function Gi(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function mn(e,t,n,r,i){let o=new Map;return dn(e,t,n,r,i,o,new Set),o}function Qi(e,t,n,r,i){let o=new Map,s=new Set;for(let a of i)a.selectionSet&&dn(e,t,n,r,a.selectionSet,o,s);return o}function dn(e,t,n,r,i,o,s){for(let a of i.selections)switch(a.kind){case u.FIELD:{if(!Sr(n,a))continue;let c=Ns(a),p=o.get(c);p!==void 0?p.push(a):o.set(c,[a]);break}case u.INLINE_FRAGMENT:{if(!Sr(n,a)||!ji(e,a,r))continue;dn(e,t,n,r,a.selectionSet,o,s);break}case u.FRAGMENT_SPREAD:{let c=a.name.value;if(s.has(c)||!Sr(n,a))continue;s.add(c);let p=t[c];if(!p||!ji(e,p,r))continue;dn(e,t,n,r,p.selectionSet,o,s);break}}}function Sr(e,t){let n=fn(Xt,t,e);if(n?.if===!0)return!1;let r=fn(zt,t,e);return r?.if!==!1}function ji(e,t,n){let r=t.typeCondition;if(!r)return!0;let i=G(e,r);return i===n?!0:ie(i)?e.isSubType(i,n):!1}function Ns(e){return e.alias?e.alias.value:e.name.value}function _r(e){return{OperationDefinition(t){if(t.operation==="subscription"){let n=e.getSchema(),r=n.getSubscriptionType();if(r){let i=t.name?t.name.value:null,o=Object.create(null),s=e.getDocument(),a=Object.create(null);for(let p of s.definitions)p.kind===u.FRAGMENT_DEFINITION&&(a[p.name.value]=p);let c=mn(n,a,o,r,t.selectionSet);if(c.size>1){let d=[...c.values()].slice(1).flat();e.reportError(new f(i!=null?`Subscription "${i}" must select only one top level field.`:"Anonymous Subscription must select only one top level field.",{nodes:d}))}for(let p of c.values())p[0].name.value.startsWith("__")&&e.reportError(new f(i!=null?`Subscription "${i}" must not select an introspection top level field.`:"Anonymous Subscription must not select an introspection top level field.",{nodes:p}))}}}}}function rt(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 xr(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=rt(i,s=>s.name.value);for(let[s,a]of o)a.length>1&&e.reportError(new f(`Argument "${r}(${s}:)" can only be defined once.`,{nodes:a.map(c=>c.name)}));return!1}}function hn(e){return{Field:t,Directive:t};function t(n){var r;let i=(r=n.arguments)!==null&&r!==void 0?r:[],o=rt(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 Lr(e){let t=Object.create(null),n=e.getSchema();return{DirectiveDefinition(r){let i=r.name.value;if(n!=null&&n.getDirective(i)){e.reportError(new f(`Directive "@${i}" already exists in the schema. It cannot be redefined.`,{nodes:r.name}));return}return t[i]?e.reportError(new f(`There can be only one directive named "@${i}".`,{nodes:[t[i],r.name]})):t[i]=r.name,!1}}}function yn(e){let t=Object.create(null),n=e.getSchema(),r=n?n.getDirectives():ve;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(_e(a)||tn(a)){let p=a.name.value;c=s[p],c===void 0&&(s[p]=c=Object.create(null))}else c=Object.create(null);for(let p of a.directives){let l=p.name.value;t[l]&&(c[l]?e.reportError(new f(`The directive "@${l}" can only be used once at this location.`,{nodes:[c[l],p]})):c[l]=p)}}}}function wr(e){let t=e.getSchema(),n=t?t.getTypeMap():Object.create(null),r=Object.create(null);return{EnumTypeDefinition:i,EnumTypeExtension:i};function i(o){var s;let a=o.name.value;r[a]||(r[a]=Object.create(null));let c=(s=o.values)!==null&&s!==void 0?s:[],p=r[a];for(let l of c){let d=l.name.value,h=n[a];B(h)&&h.getValue(d)?e.reportError(new f(`Enum value "${a}.${d}" already exists in the schema. It cannot also be defined in this type extension.`,{nodes:l.name})):p[d]?e.reportError(new f(`Enum value "${a}.${d}" can only be defined once.`,{nodes:[p[d],l.name]})):p[d]=l.name}return!1}}function Dr(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;Is(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 Is(e,t){return x(e)||w(e)||A(e)?e.getFields()[t]!=null:!1}function Ar(e){let t=Object.create(null);return{OperationDefinition:()=>!1,FragmentDefinition(n){let r=n.name.value;return t[r]?e.reportError(new f(`There can be only one fragment named "${r}".`,{nodes:[t[r],n.name]})):t[r]=n.name,!1}}}function Tn(e){let t=[],n=Object.create(null);return{ObjectValue:{enter(){t.push(n),n=Object.create(null)},leave(){let r=t.pop();r||V(!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 Fr(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 kr(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 Cr(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 Mr(e){return{OperationDefinition(t){var n;let r=(n=t.variableDefinitions)!==null&&n!==void 0?n:[],i=rt(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 Pr(e){let t={};return{OperationDefinition:{enter(){t={}}},VariableDefinition(n){t[n.variable.name.value]=n},ListValue(n){let r=We(e.getParentInputType());if(!C(r))return $e(e,n),!1},ObjectValue(n){let r=z(e.getInputType());if(!A(r))return $e(e,n),!1;let i=he(n.fields,o=>o.name.value);for(let o of Object.values(r.getFields()))if(!i[o.name]&&Ze(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&&bs(e,n,r,i,t)},ObjectField(n){let r=z(e.getParentInputType());if(!e.getInputType()&&A(r)){let o=ne(n.name.value,Object.keys(r.getFields()));e.reportError(new f(`Field "${n.name.value}" is not defined by type "${r.name}".`+Z(o),{nodes:n}))}},NullValue(n){let r=e.getInputType();O(r)&&e.reportError(new f(`Expected value of type "${y(r)}", found ${D(n)}.`,{nodes:n}))},EnumValue:n=>$e(e,n),IntValue:n=>$e(e,n),FloatValue:n=>$e(e,n),StringValue:n=>$e(e,n),BooleanValue:n=>$e(e,n)}}function $e(e,t){let n=e.getInputType();if(!n)return;let r=z(n);if(!W(r)){let i=y(n);e.reportError(new f(`Expected value of type "${i}", found ${D(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 ${D(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 ${D(t)}; `+i.message,{nodes:t,originalError:i}))}}function bs(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 Ur(e){return{VariableDefinition(t){let n=G(e.getSchema(),t.type);if(n!==void 0&&!K(n)){let r=t.variable.name.value,i=D(t.type);e.reportError(new f(`Variable "$${r}" cannot be non-input type "${i}".`,{nodes:t.type}))}}}}function $r(e){let t=Object.create(null);return{OperationDefinition:{enter(){t=Object.create(null)},leave(n){let r=e.getRecursiveVariableUsages(n);for(let{node:i,type:o,defaultValue:s}of r){let a=i.name.value,c=t[a];if(c&&o){let p=e.getSchema(),l=G(p,c.type);if(l&&!Rs(p,l,c.defaultValue,o,s)){let d=y(l),h=y(o);e.reportError(new f(`Variable "$${a}" of type "${d}" used in position expecting type "${h}".`,{nodes:[c,i]}))}}}}},VariableDefinition(n){t[n.variable.name.value]=n}}}function Rs(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 Se(e,t,a)}return Se(e,t,r)}var Vr=Object.freeze([pr]),it=Object.freeze([nr,Fr,cr,_r,rn,ir,Ur,Rr,rr,Ar,ar,dr,vr,lr,Mr,fr,mr,nn,yn,or,hn,Pr,Ir,$r,gr,Tn,...Vr]),Os=Object.freeze([ur,kr,Cr,wr,Dr,xr,Lr,rn,nn,yn,Nr,sr,hn,Tn,br]);var Gr=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 Rt=class extends Gr{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 nt(this._schema);Le(t,en(i,{VariableDefinition:()=>!1,Variable(o){r.push({node:o,type:i.getInputType(),defaultValue:i.getDefaultValue()})}})),n=r,this._variableUsages.set(t,n)}return n}getRecursiveVariableUsages(t){let n=this._recursiveVariableUsages.get(t);if(!n){n=this.getVariableUsages(t);for(let r of this.getRecursivelyReferencedFragments(t))n=n.concat(this.getVariableUsages(r));this._recursiveVariableUsages.set(t,n)}return n}getType(){return this._typeInfo.getType()}getParentType(){return this._typeInfo.getParentType()}getInputType(){return this._typeInfo.getInputType()}getParentInputType(){return this._typeInfo.getParentInputType()}getFieldDef(){return this._typeInfo.getFieldDef()}getDirective(){return this._typeInfo.getDirective()}getArgument(){return this._typeInfo.getArgument()}getEnumValue(){return this._typeInfo.getEnumValue()}};function gn(e,t,n=it,r,i=new nt(e)){var o;let s=(o=r?.maxErrors)!==null&&o!==void 0?o:100;t||S(!1,"Must provide document."),It(e);let a=Object.freeze({}),c=[],p=new Rt(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=Pn(n.map(d=>d(p)));try{Le(t,en(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 jr(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 Qr(e)}var Qr=class extends Error{constructor(t){super("Unexpected error value: "+y(t)),this.name="NonErrorThrown",this.thrownValue=t}};function Ot(e,t,n){var r;let i=Yi(e);return Ss(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 Ss(e){return Array.isArray(e.path)}var _s=Bi((e,t,n)=>Qi(e.schema,e.fragments,e.variableValues,t,n));function bn(e){arguments.length<2||S(!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;xs(t,n,r);let o=Ls(e);if(!("schema"in o))return{errors:o};try{let{operation:s}=o,a=ws(o,s,i);return ce(a)?a.then(c=>En(c,o.errors),c=>(o.errors.push(c),En(null,o.errors))):En(a,o.errors)}catch(s){return o.errors.push(s),En(null,o.errors)}}function En(e,t){return t.length===0?{data:e}:{errors:t,data:e}}function xs(e,t,n){t||S(!1,"Must provide document."),It(e),n==null||Y(n)||S(!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 Ls(e){var t,n;let{schema:r,document:i,rootValue:o,contextValue:s,variableValues:a,operationName:c,fieldResolver:p,typeResolver:l,subscribeFieldResolver:d}=e,h,T=Object.create(null);for(let $ of i.definitions)switch($.kind){case u.OPERATION_DEFINITION:if(c==null){if(h!==void 0)return[new f("Must provide operation name if query contains multiple operations.")];h=$}else((t=$.name)===null||t===void 0?void 0:t.value)===c&&(h=$);break;case u.FRAGMENT_DEFINITION:T[$.name.value]=$;break;default:}if(!h)return c!=null?[new f(`Unknown operation named "${c}".`)]:[new f("Must provide an operation.")];let g=(n=h.variableDefinitions)!==null&&n!==void 0?n:[],M=Or(r,g,a??{},{maxErrors:50});return M.errors?M.errors:{schema:r,fragments:T,rootValue:o,contextValue:s,operation:h,variableValues:M.coerced,fieldResolver:p??In,typeResolver:l??qr,subscribeFieldResolver:d??In,errors:[]}}function ws(e,t,n){let r=e.schema.getRootType(t.operation);if(r==null)throw new f(`Schema is not configured to execute ${t.operation} operation.`,{nodes:t});let i=mn(e.schema,e.fragments,e.variableValues,r,t.selectionSet),o=void 0;switch(t.operation){case U.QUERY:return vn(e,r,n,o,i);case U.MUTATION:return Ds(e,r,n,o,i);case U.SUBSCRIPTION:return vn(e,r,n,o,i)}}function Ds(e,t,n,r,i){return qi(i.entries(),(o,[s,a])=>{let c=Pe(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 vn(e,t,n,r,i){let o=Object.create(null),s=!1;try{for(let[a,c]of i.entries()){let p=Pe(r,a,t.name),l=zi(e,t,n,c,p);l!==void 0&&(o[a]=l,ce(l)&&(s=!0))}}catch(a){if(s)return jr(o).finally(()=>{throw a});throw a}return s?jr(o):o}function zi(e,t,n,r,i){var o;let s=Ms(e.schema,t,r[0]);if(!s)return;let a=s.type,c=(o=s.resolve)!==null&&o!==void 0?o:e.fieldResolver,p=As(e,s,r,t,i);try{let l=ln(s,r[0],e.variableValues),d=e.contextValue,h=c(n,l,d,p),T;return ce(h)?T=h.then(g=>St(e,a,r,p,i,g)):T=St(e,a,r,p,i,h),ce(T)?T.then(void 0,g=>{let M=Ot(g,r,ee(i));return Nn(M,a,e)}):T}catch(l){let d=Ot(l,r,ee(i));return Nn(d,a,e)}}function As(e,t,n,r,i){return{fieldName:t.name,fieldNodes:n,returnType:t.type,parentType:r,path:i,schema:e.schema,fragments:e.fragments,rootValue:e.rootValue,operation:e.operation,variableValues:e.variableValues}}function Nn(e,t,n){if(O(t))throw e;return n.errors.push(e),null}function St(e,t,n,r,i,o){if(o instanceof Error)throw o;if(O(t)){let s=St(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 Fs(e,t,n,r,i,o);if(W(t))return ks(t,o);if(ie(t))return Cs(e,t,n,r,i,o);if(x(t))return Br(e,t,n,r,i,o);V(!1,"Cannot complete value of unexpected output type: "+y(t))}function Fs(e,t,n,r,i,o){if(!et(o))throw new f(`Expected Iterable, but did not find one for field "${r.parentType.name}.${r.fieldName}".`);let s=t.ofType,a=!1,c=Array.from(o,(p,l)=>{let d=Pe(i,l,void 0);try{let h;return ce(p)?h=p.then(T=>St(e,s,n,r,d,T)):h=St(e,s,n,r,d,p),ce(h)?(a=!0,h.then(void 0,T=>{let g=Ot(T,n,ee(d));return Nn(g,s,e)})):h}catch(h){let T=Ot(h,n,ee(d));return Nn(T,s,e)}});return a?Promise.all(c):c}function ks(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 Cs(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=>Br(e,Hi(l,e,t,n,r,o),n,r,i,o)):Br(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 Br(e,t,n,r,i,o){let s=_s(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 vn(e,t,o,i,s)});if(!a)throw Ji(t,o,n)}return vn(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 qr=function(e,t,n,r){if(Y(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})},In=function(e,t,n,r){if(Y(e)||typeof e=="function"){let i=e[r.fieldName];return typeof i=="function"?e[r.fieldName](t,n,r):i}};function Ms(e,t,n){let r=n.name.value;return r===Ae.name&&e.getQueryType()===t?Ae:r===Fe.name&&e.getQueryType()===t?Fe:r===ke.name?ke:t.getFields()[r]}var E=require("@medplum/core"),Xi=require("rfc6902"),_t={READER:"reader",WRITER:"writer"},Rn=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)})}},Yr=class extends Rn{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
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)=>oa(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 console.debug("WARN: MockRepository does not support transactions"),t(void 0)}},oa=(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 Ve=require("@medplum/core");var de=require("@medplum/core"),Ki=oi(require("dataloader"));var On={base64Binary:N,boolean:q,canonical:N,code:N,date:N,dateTime:N,decimal:le,id:Ee,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":q,"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:de.Operator.EQUALS,value:(0,de.getReferenceString)(t)}}return n=Object.fromEntries(Object.entries(n).map(([o,s])=>[sa(o),s])),{searchRequest:(0,de.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 Hr(e,t){e.count=Math.min(e.count??de.DEFAULT_SEARCH_COUNT,t??de.DEFAULT_MAX_SEARCH_COUNT)}function sa(e){return e.startsWith("_")?e:e.replaceAll("_","-")}function Jr(e){return e.replaceAll("-","_")}function aa(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 Sn(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);Hr(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(h=>h.resource);let p=aa(s);return(n.searchDataLoaders[p]??=ca(n.repo,s,c)).load(a)}function ca(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 xt(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,de.getSearchParameters)(e);if(n)for(let[r,i]of Object.entries(n))t[Jr(r)]={type:N,description:i.description};return t}function zr(e,t){return e.fieldNodes.some(n=>n.selectionSet?.selections.some(r=>r.kind===u.FIELD&&r.name.value===t))}function to(e){return{resourceType:"OperationOutcome",issue:e.map(t=>({severity:"error",code:"invalid",details:{text:t.message}}))}}var no={...On};function Lt(e,t){let n=no[e];return n||(n=ua(e,t),no[e]=n),n}function ua(e,t){let n=(0,Ve.getDataType)(e);return new De({name:e+t,description:n.description,fields:()=>pa(e,t)})}function pa(e,t){let n={};if((0,Ve.isResourceType)(e)){let r={description:"The type of resource",type:N};n.resourceType=r}return la(e,n,t),n}function la(e,t,n){let r=(0,Ve.getDataType)(e);for(let[i,o]of Object.entries(r.elements))for(let s of o.type)fa(t,i,o,s,n)}function fa(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:Lt(o,i)};n.max>1&&(s.type=new P(new R(Lt(o,i)))),n.min>0&&!t.endsWith("[x]")&&(s.type=new R(s.type));let a=t.split(".").pop().replace("[x]",(0,Ve.capitalize)(r.code));e[a]=s}var F=require("@medplum/core");var _n={...On};function Ge(e){let t=_n[e];return t||(t=Xr(e),_n[e]=t),t}function Xr(e){if(e==="ResourceList")return new we({name:"ResourceList",types:()=>(0,F.getResourceTypes)().map(Ge).filter(n=>!!n),resolveType:Ia});let t=(0,F.getDataType)(e);return new H({name:e,description:t.description,fields:()=>da(e)})}function da(e){let t={};return ma(e,t),ga(e,t),t}function ma(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:Ge("ResourceList"),resolve:Na});for(let[r,i]of Object.entries(n.elements))for(let o of i.type)ha(t,r,i,o)}function ha(e,t,n,r){let i=r.code;(i==="Element"||i==="BackboneElement")&&(i=n.type[0].code),i==="Resource"&&(i="ResourceList");let o={description:n.description,type:Ea(n,i,t),resolve:va};n.max>1&&(o.args=ya(i));let s=t.split(".").pop().replace("[x]",(0,F.capitalize)(r.code));e[s]=o}function ya(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)Ta(t,r,i,o)}return t}function Ta(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 ga(e,t){for(let n of(0,F.getResourceTypes)()){let r=Ge(n),i=(0,F.getSearchParameters)(n),o={},s=0;if(i)for(let[a,c]of Object.entries(i))c.target?.includes(e)&&(o[Jr(a)]={value:a},s++);if(s>0){let a=new Ie({name:e+"_"+n+"_reference",values:o}),c=xt(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:Sn}}}}function Ea(e,t,n){let r=Ge(t);return e.max>1&&(r=new P(new R(r))),e.min!==0&&!n.endsWith("[x]")&&(r=new R(r)),r}async function va(e,t,n,r){let i=e?.[r.fieldName];if(!t||!i)return i;let{_offset:o,_count:s,fhirpath:a,...c}=t,p=i;for(let[l,d]of Object.entries(c))p=p.filter(h=>h[l]===d);return a&&(p=p.filter(l=>(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 Na(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 Ia(e){let t=e?.resourceType;if(t)return Ge(t).name}var ba=new k.LRUCache,Kr;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=$t(i)}catch{return[(0,k.badRequest)("GraphQL syntax error.")]}let c=Sa(),p=[...it,Pa(n,e.config?.graphqlMaxDepth),$a(n)],l=gn(c,a,p);if(l.length>0)return[to(l)];let d=Ra(i);if(d&&!n.options?.introspectionEnabled)return[k.forbidden];!r?.batch&&!Oa(i)&&t.setMode(_t.READER);let h=new ro.default(g=>t.readReferences(g)),T=d&&ba.get(i);if(!T){let g={repo:t,config:e.config,dataLoader:h,searchCount:0,searchDataLoaders:Object.create(null)};T=await bn({schema:c,document:a,contextValue:g,operationName:o,variableValues:s})}return[k.allOk,T,{contentType:k.ContentType.JSON}]}function Ra(e){return e.includes("query IntrospectionQuery")||e.includes("__schema")}function Oa(e){return e.includes("mutation")}function Sa(){return Kr||(Kr=_a()),Kr}function _a(){for(let n of(0,k.getResourceTypes)())_n[n]=Xr(n);let e={},t={};for(let n of(0,k.getResourceTypes)()){let r=Ge(n);e[n]={type:r,args:{id:{type:new R(Ee),description:n+" ID"}},resolve:Aa},e[n+"List"]={type:new P(r),args:xt(n),resolve:Sn},e[n+"Connection"]={type:wa(n,r),args:xt(n),resolve:Da},t[n+"Create"]={type:r,args:xa(n),resolve:Fa},t[n+"Update"]={type:r,args:La(n),resolve:ka},t[n+"Delete"]={type:r,args:{id:{type:new R(Ee),description:n+" ID"}},resolve:Ca}}return new Ce({query:new H({name:"QueryType",fields:e}),mutation:new H({name:"MutationType",fields:t})})}function xa(e){return{res:{type:new R(Lt(e,"Create")),description:e+" Create"}}}function La(e){return{id:{type:new R(Ee),description:e+" ID"},res:{type:new R(Lt(e,"Update")),description:e+" Update"}}}function wa(e,t){return new H({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 H({name:e+"ConnectionEdge",fields:{mode:{type:N},score:{type:le},resource:{type:t}}}))}}})}async function Da(e,t,n,r){let i=r.fieldName,o=i.substring(0,i.length-10),s=eo(o,e,t);zr(r,"count")&&(s.total="accurate"),zr(r,"edges")||(s.count=0),Hr(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 Aa(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 Fa(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 ka(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 Ca(e,t,n,r){let i=r.fieldName,o=i.substring(0,i.length-6);await n.repo.deleteResource(o,t.id)}var Ma=12,Pa=(e,t=Ma)=>n=>new Wr(n,e,t),Wr=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}},Ua=1e4,$a=(e,t)=>n=>new Zr(n,e,t),Zr=class{constructor(t,n,r){this.context=t,this.maxCost=r?.maxCost??Ua,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;Va(r)?(this.log("Found search field",r.name.value),i=8,o=this.getCount(r.arguments)??20):Ga(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 Va(e){return e.name.value.endsWith("List")}function Ga(e){return e.name.value==="resource"}var wt=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=ja(c,t,o);p>a&&(s=c,a=p)}if(s)return{handler:s.handler,path:o.join("/"),params:Qa(s,o),query:i?Ba(n):void 0,data:s.data}}};function ja(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 Ba(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 qa(e,t,n){let r=e.body;if(r.resourceType!=="Bundle")return[(0,_.badRequest)("Not a bundle")];let i=await ai(e,t,n,r);return[_.allOk,i]}async function Ya(e,t,n,r){ti(e,t,r);let{resourceType:i}=e.params,o=await t.search((0,_.parseSearchRequest)(i,e.query));return[_.allOk,o]}async function Ha(e,t,n,r){ti(e,t,r);let i=(0,_.parseSearchRequest)("MultipleTypes",e.query);if(!i.types||i.types.length===0)return[(0,_.badRequest)("No types specified")];let o=await t.search(i);return[_.allOk,o]}async function Ja(e,t,n,r){ti(e,t,r);let{resourceType:i}=e.params,o=e.body,s=await t.search((0,_.parseSearchRequest)(i,o));return[_.allOk,s]}function ti(e,t,n){!n?.batch&&e.config?.searchOnReader&&t.setMode(_t.READER)}async function za(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,_.singularize)(e.headers["if-none-exist"]),c=await t.conditionalCreate(o,(0,_.parseSearchRequest)(`${i}?${a}`),{assignedId:s});return[c.outcome,c.resource]}return oo(i,o,t,{assignedId:s})}async function oo(e,t,n,r){if(t.resourceType!==e)return[(0,_.badRequest)(`Incorrect resource type: expected ${e}, but found ${t.resourceType||"<EMPTY>"}`)];let i=await n.createResource(t,r);return[_.created,i]}async function Xa(e,t){let{resourceType:n,id:r}=e.params,i=await t.readResource(n,r);return[_.allOk,i]}async function Ka(e,t){let{resourceType:n,id:r}=e.params,i=await t.readHistory(n,r);return[_.allOk,i]}async function Wa(e,t){let{resourceType:n,id:r,vid:i}=e.params,o=await t.readVersion(n,r,i);return[_.allOk,o]}async function Za(e,t){let{resourceType:n,id:r}=e.params,i=e.body;return so(n,r,i,t,{ifMatch:ic(e.headers?.["if-match"])})}async function so(e,t,n,r,i){if(n.resourceType!==e)return[(0,_.badRequest)("Incorrect resource type")];if(n.id!==t)return[(0,_.badRequest)("Incorrect resource ID")];let o=await r.updateResource(n,i);return[_.allOk,o]}async function ec(e,t,n,r){let{resourceType:i}=e.params,o=e.body,s=(0,_.parseSearchRequest)(i,e.query),a=await t.conditionalUpdate(o,s,{assignedId:r?.batch});return[a.outcome,a.resource]}async function tc(e,t){let{resourceType:n,id:r}=e.params;return await t.deleteResource(n,r),[_.allOk]}async function nc(e,t){let{resourceType:n}=e.params,r=(0,_.parseSearchRequest)(n,e.query);return await t.conditionalDelete(r),[_.allOk]}async function rc(e,t){let{resourceType:n,id:r}=e.params,i=e.body;if(!i)return[(0,_.badRequest)("Empty patch body")];if(!Array.isArray(i))return[(0,_.badRequest)("Patch body must be an array")];let o=await t.patchResource(n,r,i);return[_.allOk,o]}var ei=class extends _.EventTarget{constructor(n={}){super();this.router=new wt;this.options=n,this.router.add("GET","",Ha,{interaction:"search-system"}),this.router.add("POST","",qa,{interaction:"batch"}),this.router.add("GET",":resourceType",Ya,{interaction:"search-type"}),this.router.add("POST",":resourceType/_search",Ja,{interaction:"search-type"}),this.router.add("POST",":resourceType",za,{interaction:"create"}),this.router.add("GET",":resourceType/:id",Xa,{interaction:"read"}),this.router.add("GET",":resourceType/:id/_history",Ka,{interaction:"history-instance"}),this.router.add("GET",":resourceType/:id/_history/:vid",Wa,{interaction:"vread"}),this.router.add("PUT",":resourceType/:id",Za,{interaction:"update"}),this.router.add("PUT",":resourceType",ec,{interaction:"update"}),this.router.add("DELETE",":resourceType/:id",tc,{interaction:"delete"}),this.router.add("DELETE",":resourceType",nc,{interaction:"delete"}),this.router.add("PATCH",":resourceType/:id",rc,{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 _.OperationOutcomeError((0,_.badRequest)("FhirRequest must specify url instead of pathname"));let o=this.find(n.method,i);if(!o)return[_.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,_.normalizeOperationOutcome)(l)]}}log(n,r,i){let o={type:n,message:r,data:i};this.dispatchEvent(o)}};function ic(e){if(!e)return;let t=/"([^"]+)"/.exec(e);return t?t[1]:void 0}function oc(e,t,n){return{method:e,url:t,pathname:"",query:{},params:{},body:n}}0&&(module.exports={FhirRepository,FhirRouter,MemoryRepository,RepositoryMode,Router,createResourceImpl,makeSimpleRequest,updateResourceImpl});
|
|
55
55
|
//# sourceMappingURL=index.cjs.map
|