@medplum/fhir-router 5.1.5 → 5.1.7
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 +1 -1
- package/dist/cjs/index.cjs.map +3 -3
- package/dist/esm/index.mjs +1 -1
- package/dist/esm/index.mjs.map +3 -3
- package/package.json +5 -5
package/dist/esm/index.mjs
CHANGED
|
@@ -56,6 +56,6 @@ spurious results.`)}}return!1};var ze=class{constructor(t,r="GraphQL request",n=
|
|
|
56
56
|
|
|
57
57
|
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 N(v),resolve:e=>e.name},description:{type:v,resolve:e=>e.description},isRepeatable:{type:new N(G),resolve:e=>e.isRepeatable},locations:{type:new N(new D(new N(Xr))),resolve:e=>e.locations},args:{type:new N(new D(new N(_t))),args:{includeDeprecated:{type:G,defaultValue:!1}},resolve(e,{includeDeprecated:t}){return t?e.args:e.args.filter(r=>r.deprecationReason==null)}}})}),Xr=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."}}}),de=new B({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 N(Zr),resolve(e){if(Ee(e))return q.SCALAR;if(S(e))return q.OBJECT;if(_(e))return q.INTERFACE;if(J(e))return q.UNION;if(V(e))return q.ENUM;if(x(e))return q.INPUT_OBJECT;if(w(e))return q.LIST;if(R(e))return q.NON_NULL;k(!1,`Unexpected type: "${y(e)}".`)}},name:{type:v,resolve:e=>"name"in e?e.name:void 0},description:{type:v,resolve:e=>"description"in e?e.description:void 0},specifiedByURL:{type:v,resolve:e=>"specifiedByURL"in e?e.specifiedByURL:void 0},fields:{type:new D(new N(Kr)),args:{includeDeprecated:{type:G,defaultValue:!1}},resolve(e,{includeDeprecated:t}){if(S(e)||_(e)){let r=Object.values(e.getFields());return t?r:r.filter(n=>n.deprecationReason==null)}}},interfaces:{type:new D(new N(de)),resolve(e){if(S(e)||_(e))return e.getInterfaces()}},possibleTypes:{type:new D(new N(de)),resolve(e,t,r,{schema:n}){if(ie(e))return n.getPossibleTypes(e)}},enumValues:{type:new D(new N(Wr)),args:{includeDeprecated:{type:G,defaultValue:!1}},resolve(e,{includeDeprecated:t}){if(V(e)){let r=e.getValues();return t?r:r.filter(n=>n.deprecationReason==null)}}},inputFields:{type:new D(new N(_t)),args:{includeDeprecated:{type:G,defaultValue:!1}},resolve(e,{includeDeprecated:t}){if(x(e)){let r=Object.values(e.getFields());return t?r:r.filter(n=>n.deprecationReason==null)}}},ofType:{type:de,resolve:e=>"ofType"in e?e.ofType:void 0},isOneOf:{type:G,resolve:e=>{if(x(e))return e.isOneOf}}})}),Kr=new B({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 N(v),resolve:e=>e.name},description:{type:v,resolve:e=>e.description},args:{type:new N(new D(new N(_t))),args:{includeDeprecated:{type:G,defaultValue:!1}},resolve(e,{includeDeprecated:t}){return t?e.args:e.args.filter(r=>r.deprecationReason==null)}},type:{type:new N(de),resolve:e=>e.type},isDeprecated:{type:new N(G),resolve:e=>e.deprecationReason!=null},deprecationReason:{type:v,resolve:e=>e.deprecationReason}})}),_t=new B({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 N(v),resolve:e=>e.name},description:{type:v,resolve:e=>e.description},type:{type:new N(de),resolve:e=>e.type},defaultValue:{type:v,description:"A GraphQL-formatted string representing the default value for this input value.",resolve(e){let{type:t,defaultValue:r}=e,n=it(r,t);return n?L(n):null}},isDeprecated:{type:new N(G),resolve:e=>e.deprecationReason!=null},deprecationReason:{type:v,resolve:e=>e.deprecationReason}})}),Wr=new B({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 N(v),resolve:e=>e.name},description:{type:v,resolve:e=>e.description},isDeprecated:{type:new N(G),resolve:e=>e.deprecationReason!=null},deprecationReason:{type:v,resolve:e=>e.deprecationReason}})}),q;(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"})(q||(q={}));var Zr=new Ie({name:"__TypeKind",description:"An enum describing what kind of type a given `__Type` is.",values:{SCALAR:{value:q.SCALAR,description:"Indicates this type is a scalar."},OBJECT:{value:q.OBJECT,description:"Indicates this type is an object. `fields` and `interfaces` are valid fields."},INTERFACE:{value:q.INTERFACE,description:"Indicates this type is an interface. `fields`, `interfaces`, and `possibleTypes` are valid fields."},UNION:{value:q.UNION,description:"Indicates this type is a union. `possibleTypes` is a valid field."},ENUM:{value:q.ENUM,description:"Indicates this type is an enum. `enumValues` is a valid field."},INPUT_OBJECT:{value:q.INPUT_OBJECT,description:"Indicates this type is an input object. `inputFields` is a valid field."},LIST:{value:q.LIST,description:"Indicates this type is a list. `ofType` is a valid field."},NON_NULL:{value:q.NON_NULL,description:"Indicates this type is a non-null. `ofType` is a valid field."}}}),ke={name:"__schema",type:new N(St),description:"Access the current type schema of this server.",args:[],resolve:(e,t,r,{schema:n})=>n,deprecationReason:void 0,extensions:Object.create(null),astNode:void 0},Me={name:"__type",type:de,description:"Request the type information of a single type.",args:[{name:"name",description:void 0,type:new N(v),defaultValue:void 0,deprecationReason:void 0,extensions:Object.create(null),astNode:void 0}],resolve:(e,{name:t},r,{schema:n})=>n.getType(t),deprecationReason:void 0,extensions:Object.create(null),astNode:void 0},Pe={name:"__typename",type:new N(v),description:"The name of the current Object type at runtime.",args:[],resolve:(e,t,r,{parentType:n})=>n.name,deprecationReason:void 0,extensions:Object.create(null),astNode:void 0},ir=Object.freeze([St,zr,Xr,de,Kr,_t,Wr,Zr]);function en(e){return ir.some(({name:t})=>e.name===t)}function tn(e){return te(e,Ue)}function or(e){if(!tn(e))throw new Error(`Expected ${y(e)} to be a GraphQL schema.`);return e}var Ue=class{constructor(t){var r,n;this.__validationErrors=t.assumeValid===!0?[]:void 0,Q(t)||O(!1,"Must provide configuration object."),!t.types||Array.isArray(t.types)||O(!1,`"types" must be Array if provided but got: ${y(t.types)}.`),!t.directives||Array.isArray(t.directives)||O(!1,`"directives" must be Array if provided but got: ${y(t.directives)}.`),this.description=t.description,this.extensions=ne(t.extensions),this.astNode=t.astNode,this.extensionASTNodes=(r=t.extensionASTNodes)!==null&&r!==void 0?r:[],this._queryType=t.query,this._mutationType=t.mutation,this._subscriptionType=t.subscription,this._directives=(n=t.directives)!==null&&n!==void 0?n: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(Ot(o))for(let s of o.args)Ne(s.type,i);Ne(St,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||O(!1,"One of the provided types for building the Schema is missing a name."),this._typeMap[s]!==void 0)throw new Error(`Schema must contain uniquely named types but contains multiple types named "${s}".`);if(this._typeMap[s]=o,_(o)){for(let a of o.getInterfaces())if(_(a)){let c=this._implementationsMap[a.name];c===void 0&&(c=this._implementationsMap[a.name]={objects:[],interfaces:[]}),c.interfaces.push(o)}}else if(S(o)){for(let a of o.getInterfaces())if(_(a)){let c=this._implementationsMap[a.name];c===void 0&&(c=this._implementationsMap[a.name]={objects:[],interfaces:[]}),c.objects.push(o)}}}}get[Symbol.toStringTag](){return"GraphQLSchema"}getQueryType(){return this._queryType}getMutationType(){return this._mutationType}getSubscriptionType(){return this._subscriptionType}getRootType(t){switch(t){case C.QUERY:return this.getQueryType();case C.MUTATION:return this.getMutationType();case C.SUBSCRIPTION:return this.getSubscriptionType()}}getTypeMap(){return this._typeMap}getType(t){return this.getTypeMap()[t]}getPossibleTypes(t){return J(t)?t.getTypes():this.getImplementations(t).objects}getImplementations(t){let r=this._implementationsMap[t.name];return r??{objects:[],interfaces:[]}}isSubType(t,r){let n=this._subTypeMap[t.name];if(n===void 0){if(n=Object.create(null),J(t))for(let i of t.getTypes())n[i.name]=!0;else{let i=this.getImplementations(t);for(let o of i.objects)n[o.name]=!0;for(let o of i.interfaces)n[o.name]=!0}this._subTypeMap[t.name]=n}return n[r.name]!==void 0}getDirectives(){return this._directives}getDirective(t){return this.getDirectives().find(r=>r.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 r=H(e);if(!t.has(r)){if(t.add(r),J(r))for(let n of r.getTypes())Ne(n,t);else if(S(r)||_(r)){for(let n of r.getInterfaces())Ne(n,t);for(let n of Object.values(r.getFields())){Ne(n.type,t);for(let i of n.args)Ne(i.type,t)}}else if(x(r))for(let n of Object.values(r.getFields()))Ne(n.type,t)}return t}function ji(e){if(or(e),e.__validationErrors)return e.__validationErrors;let t=new nn(e);cs(t),us(t),ps(t);let r=t.getErrors();return e.__validationErrors=r,r}function Lt(e){let t=ji(e);if(t.length!==0)throw new Error(t.map(r=>r.message).join(`
|
|
58
58
|
|
|
59
|
-
`))}var nn=class{constructor(t){this._errors=[],this.schema=t}reportError(t,r){let n=Array.isArray(r)?r.filter(Boolean):r;this._errors.push(new f(t,{nodes:n}))}getErrors(){return this._errors}};function cs(e){let t=e.schema,r=t.getQueryType();if(!r)e.reportError("Query root type must be provided.",t.astNode);else if(!S(r)){var n;e.reportError(`Query root type must be Object type, it cannot be ${y(r)}.`,(n=rn(t,C.QUERY))!==null&&n!==void 0?n:r.astNode)}let i=t.getMutationType();if(i&&!S(i)){var o;e.reportError(`Mutation root type must be Object type if provided, it cannot be ${y(i)}.`,(o=rn(t,C.MUTATION))!==null&&o!==void 0?o:i.astNode)}let s=t.getSubscriptionType();if(s&&!S(s)){var a;e.reportError(`Subscription root type must be Object type if provided, it cannot be ${y(s)}.`,(a=rn(t,C.SUBSCRIPTION))!==null&&a!==void 0?a:s.astNode)}}function rn(e,t){var r;return(r=[e.astNode,...e.extensionASTNodes].flatMap(n=>{var i;return(i=n?.operationTypes)!==null&&i!==void 0?i:[]}).find(n=>n.operation===t))===null||r===void 0?void 0:r.type}function us(e){for(let r of e.schema.getDirectives()){if(!Ot(r)){e.reportError(`Expected directive but got: ${y(r)}.`,r?.astNode);continue}$e(e,r),r.locations.length===0&&e.reportError(`Directive @${r.name} must include 1 or more locations.`,r.astNode);for(let n of r.args)if($e(e,n),z(n.type)||e.reportError(`The type of @${r.name}(${n.name}:) must be Input Type but got: ${y(n.type)}.`,n.astNode),Oe(n)&&n.deprecationReason!=null){var t;e.reportError(`Required argument @${r.name}(${n.name}:) cannot be deprecated.`,[on(n.astNode),(t=n.astNode)===null||t===void 0?void 0:t.type])}}}function $e(e,t){t.name.startsWith("__")&&e.reportError(`Name "${t.name}" must not begin with "__", which is reserved by GraphQL introspection.`,t.astNode)}function ps(e){let t=Ts(e),r=e.schema.getTypeMap();for(let n of Object.values(r)){if(!Xt(n)){e.reportError(`Expected GraphQL named type but got: ${y(n)}.`,n.astNode);continue}en(n)||$e(e,n),S(n)||_(n)?($i(e,n),Vi(e,n)):J(n)?ds(e,n):V(n)?ms(e,n):x(n)&&(hs(e,n),t(n))}}function $i(e,t){let r=Object.values(t.getFields());r.length===0&&e.reportError(`Type ${t.name} must define one or more fields.`,[t.astNode,...t.extensionASTNodes]);for(let s of r){if($e(e,s),!be(s.type)){var n;e.reportError(`The type of ${t.name}.${s.name} must be Output Type but got: ${y(s.type)}.`,(n=s.astNode)===null||n===void 0?void 0:n.type)}for(let a of s.args){let c=a.name;if($e(e,a),!z(a.type)){var i;e.reportError(`The type of ${t.name}.${s.name}(${c}:) must be Input Type but got: ${y(a.type)}.`,(i=a.astNode)===null||i===void 0?void 0:i.type)}if(Oe(a)&&a.deprecationReason!=null){var o;e.reportError(`Required argument ${t.name}.${s.name}(${c}:) cannot be deprecated.`,[on(a.astNode),(o=a.astNode)===null||o===void 0?void 0:o.type])}}}}function Vi(e,t){let r=Object.create(null);for(let n of t.getInterfaces()){if(!_(n)){e.reportError(`Type ${y(t)} must only implement Interface types, it cannot implement ${y(n)}.`,xt(t,n));continue}if(t===n){e.reportError(`Type ${t.name} cannot implement itself because it would create a circular reference.`,xt(t,n));continue}if(r[n.name]){e.reportError(`Type ${t.name} can only implement ${n.name} once.`,xt(t,n));continue}r[n.name]=!0,fs(e,t,n),ls(e,t,n)}}function ls(e,t,r){let n=t.getFields();for(let c of Object.values(r.getFields())){let p=c.name,l=n[p];if(!l){e.reportError(`Interface field ${r.name}.${p} expected but ${t.name} does not provide it.`,[c.astNode,t.astNode,...t.extensionASTNodes]);continue}if(!Le(e.schema,l.type,c.type)){var i,o;e.reportError(`Interface field ${r.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 ${r.name}.${p}(${h}:) expected but ${t.name}.${p} does not provide it.`,[d.astNode,l.astNode]);continue}if(!Zt(d.type,T.type)){var s,a;e.reportError(`Interface field argument ${r.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)&&Oe(d)&&e.reportError(`Object field ${t.name}.${p} includes required argument ${h} that is missing from the Interface field ${r.name}.${p}.`,[d.astNode,c.astNode])}}}function fs(e,t,r){let n=t.getInterfaces();for(let i of r.getInterfaces())n.includes(i)||e.reportError(i===t?`Type ${t.name} cannot implement ${r.name} because it would create a circular reference.`:`Type ${t.name} must implement ${i.name} because it is implemented by ${r.name}.`,[...xt(r,i),...xt(t,r)])}function ds(e,t){let r=t.getTypes();r.length===0&&e.reportError(`Union type ${t.name} must define one or more member types.`,[t.astNode,...t.extensionASTNodes]);let n=Object.create(null);for(let i of r){if(n[i.name]){e.reportError(`Union type ${t.name} can only include type ${i.name} once.`,Gi(t,i.name));continue}n[i.name]=!0,S(i)||e.reportError(`Union type ${t.name} can only include Object types, it cannot include ${y(i)}.`,Gi(t,String(i)))}}function ms(e,t){let r=t.getValues();r.length===0&&e.reportError(`Enum type ${t.name} must define one or more values.`,[t.astNode,...t.extensionASTNodes]);for(let n of r)$e(e,n)}function hs(e,t){let r=Object.values(t.getFields());r.length===0&&e.reportError(`Input Object type ${t.name} must define one or more fields.`,[t.astNode,...t.extensionASTNodes]);for(let o of r){if($e(e,o),!z(o.type)){var n;e.reportError(`The type of ${t.name}.${o.name} must be Input Type but got: ${y(o.type)}.`,(n=o.astNode)===null||n===void 0?void 0:n.type)}if(rt(o)&&o.deprecationReason!=null){var i;e.reportError(`Required input field ${t.name}.${o.name} cannot be deprecated.`,[on(o.astNode),(i=o.astNode)===null||i===void 0?void 0:i.type])}t.isOneOf&&ys(t,o,e)}}function ys(e,t,r){if(R(t.type)){var n;r.reportError(`OneOf input field ${e.name}.${t.name} must be nullable.`,(n=t.astNode)===null||n===void 0?void 0:n.type)}t.defaultValue!==void 0&&r.reportError(`OneOf input field ${e.name}.${t.name} cannot have a default value.`,t.astNode)}function Ts(e){let t=Object.create(null),r=[],n=Object.create(null);return i;function i(o){if(t[o.name])return;t[o.name]=!0,n[o.name]=r.length;let s=Object.values(o.getFields());for(let a of s)if(R(a.type)&&x(a.type.ofType)){let c=a.type.ofType,p=n[c.name];if(r.push(a),p===void 0)i(c);else{let l=r.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))}r.pop()}n[o.name]=void 0}}function xt(e,t){let{astNode:r,extensionASTNodes:n}=e;return(r!=null?[r,...n]:n).flatMap(o=>{var s;return(s=o.interfaces)!==null&&s!==void 0?s:[]}).filter(o=>o.name.value===t.name)}function Gi(e,t){let{astNode:r,extensionASTNodes:n}=e;return(r!=null?[r,...n]:n).flatMap(o=>{var s;return(s=o.types)!==null&&s!==void 0?s:[]}).filter(o=>o.name.value===t)}function on(e){var t;return e==null||(t=e.directives)===null||t===void 0?void 0:t.find(r=>r.name.value===nr.name)}function P(e,t){switch(t.kind){case u.LIST_TYPE:{let r=P(e,t.type);return r&&new D(r)}case u.NON_NULL_TYPE:{let r=P(e,t.type);return r&&new N(r)}case u.NAMED_TYPE:return e.getType(t.name.value)}}var ot=class{constructor(t,r,n){this._schema=t,this._typeStack=[],this._parentTypeStack=[],this._inputTypeStack=[],this._fieldDefStack=[],this._defaultValueStack=[],this._directive=null,this._argument=null,this._enumValue=null,this._getFieldDef=n??gs,r&&(z(r)&&this._inputTypeStack.push(r),ce(r)&&this._parentTypeStack.push(r),be(r)&&this._typeStack.push(r))}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 r=this._schema;switch(t.kind){case u.SELECTION_SET:{let i=H(this.getType());this._parentTypeStack.push(ce(i)?i:void 0);break}case u.FIELD:{let i=this.getParentType(),o,s;i&&(o=this._getFieldDef(r,i,t),o&&(s=o.type)),this._fieldDefStack.push(o),this._typeStack.push(be(s)?s:void 0);break}case u.DIRECTIVE:this._directive=r.getDirective(t.name.value);break;case u.OPERATION_DEFINITION:{let i=r.getRootType(t.operation);this._typeStack.push(S(i)?i:void 0);break}case u.INLINE_FRAGMENT:case u.FRAGMENT_DEFINITION:{let i=t.typeCondition,o=i?P(r,i):H(this.getType());this._typeStack.push(be(o)?o:void 0);break}case u.VARIABLE_DEFINITION:{let i=P(r,t.type);this._inputTypeStack.push(z(i)?i:void 0);break}case u.ARGUMENT:{var n;let i,o,s=(n=this.getDirective())!==null&&n!==void 0?n: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(z(o)?o:void 0);break}case u.LIST:{let i=tt(this.getInputType()),o=w(i)?i.ofType:i;this._defaultValueStack.push(void 0),this._inputTypeStack.push(z(o)?o:void 0);break}case u.OBJECT_FIELD:{let i=H(this.getInputType()),o,s;x(i)&&(s=i.getFields()[t.name.value],s&&(o=s.type)),this._defaultValueStack.push(s?s.defaultValue:void 0),this._inputTypeStack.push(z(o)?o:void 0);break}case u.ENUM:{let i=H(this.getInputType()),o;V(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 gs(e,t,r){let n=r.name.value;if(n===ke.name&&e.getQueryType()===t)return ke;if(n===Me.name&&e.getQueryType()===t)return Me;if(n===Pe.name&&ce(t))return Pe;if(S(t)||_(t))return t.getFields()[n]}function sr(e,t){return{enter(...r){let n=r[0];e.enter(n);let i=We(t,n.kind).enter;if(i){let o=i.apply(t,r);return o!==void 0&&(e.leave(n),mt(o)&&e.enter(o)),o}},leave(...r){let n=r[0],i=We(t,n.kind).leave,o;return i&&(o=i.apply(t,r)),e.leave(n),o}}}function sn(e){return e.kind===u.OPERATION_DEFINITION||e.kind===u.FRAGMENT_DEFINITION}function an(e){return e.kind===u.SCHEMA_DEFINITION||we(e)||e.kind===u.DIRECTIVE_DEFINITION}function we(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 cn(e){return e.kind===u.SCHEMA_EXTENSION||ar(e)}function ar(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 un(e){return{Document(t){for(let r of t.definitions)if(!sn(r)){let n=r.kind===u.SCHEMA_DEFINITION||r.kind===u.SCHEMA_EXTENSION?"schema":'"'+r.name.value+'"';e.reportError(new f(`The ${n} definition is not executable.`,{nodes:r}))}return!1}}}function pn(e){return{Field(t){let r=e.getParentType();if(r&&!e.getFieldDef()){let i=e.getSchema(),o=t.name.value,s=Z("to use an inline fragment on",Es(i,r,o));s===""&&(s=Z(vs(r,o))),e.reportError(new f(`Cannot query field "${o}" on type "${r.name}".`+s,{nodes:t}))}}}}function Es(e,t,r){if(!ie(t))return[];let n=new Set,i=Object.create(null);for(let s of e.getPossibleTypes(t))if(s.getFields()[r]){n.add(s),i[s.name]=1;for(let a of s.getInterfaces()){var o;a.getFields()[r]&&(n.add(a),i[a.name]=((o=i[a.name])!==null&&o!==void 0?o:0)+1)}}return[...n].sort((s,a)=>{let c=i[a.name]-i[s.name];return c!==0?c:_(s)&&e.isSubType(s,a)?-1:_(a)&&e.isSubType(a,s)?1:Xe(s.name,a.name)}).map(s=>s.name)}function vs(e,t){if(S(e)||_(e)){let r=Object.keys(e.getFields());return re(t,r)}return[]}function ln(e){return{InlineFragment(t){let r=t.typeCondition;if(r){let n=P(e.getSchema(),r);if(n&&!ce(n)){let i=L(r);e.reportError(new f(`Fragment cannot condition on non composite type "${i}".`,{nodes:r}))}}},FragmentDefinition(t){let r=P(e.getSchema(),t.typeCondition);if(r&&!ce(r)){let n=L(t.typeCondition);e.reportError(new f(`Fragment "${t.name.value}" cannot condition on non composite type "${n}".`,{nodes:t.typeCondition}))}}}}function fn(e){return{...dn(e),Argument(t){let r=e.getArgument(),n=e.getFieldDef(),i=e.getParentType();if(!r&&n&&i){let o=t.name.value,s=n.args.map(c=>c.name),a=re(o,s);e.reportError(new f(`Unknown argument "${o}" on field "${i.name}.${n.name}".`+Z(a),{nodes:t}))}}}}function dn(e){let t=Object.create(null),r=e.getSchema(),n=r?r.getDirectives():ve;for(let s of n)t[s.name]=s.args.map(a=>a.name);let i=e.getDocument().definitions;for(let s of i)if(s.kind===u.DIRECTIVE_DEFINITION){var o;let a=(o=s.arguments)!==null&&o!==void 0?o:[];t[s.name.value]=a.map(c=>c.name.value)}return{Directive(s){let a=s.name.value,c=t[a];if(s.arguments&&c)for(let p of s.arguments){let l=p.name.value;if(!c.includes(l)){let d=re(l,c);e.reportError(new f(`Unknown argument "${l}" on directive "@${a}".`+Z(d),{nodes:p}))}}return!1}}}function cr(e){let t=Object.create(null),r=e.getSchema(),n=r?r.getDirectives():ve;for(let o of n)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=Ns(p);h&&!d.includes(h)&&e.reportError(new f(`Directive "@${l}" may not be used on ${h}.`,{nodes:o}))}}}function Ns(e){let t=e[e.length-1];switch("kind"in t||k(!1),t.kind){case u.OPERATION_DEFINITION:return Is(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 r=e[e.length-3];return"kind"in r||k(!1),r.kind===u.INPUT_OBJECT_TYPE_DEFINITION?I.INPUT_FIELD_DEFINITION:I.ARGUMENT_DEFINITION}default:k(!1,"Unexpected kind: "+y(t.kind))}}function Is(e){switch(e){case C.QUERY:return I.QUERY;case C.MUTATION:return I.MUTATION;case C.SUBSCRIPTION:return I.SUBSCRIPTION}}function mn(e){return{FragmentSpread(t){let r=t.name.value;e.getFragment(r)||e.reportError(new f(`Unknown fragment "${r}".`,{nodes:t.name}))}}}function ur(e){let t=e.getSchema(),r=t?t.getTypeMap():Object.create(null),n=Object.create(null);for(let o of e.getDocument().definitions)we(o)&&(n[o.name.value]=!0);let i=[...Object.keys(r),...Object.keys(n)];return{NamedType(o,s,a,c,p){let l=o.name.value;if(!r[l]&&!n[l]){var d;let h=(d=p[2])!==null&&d!==void 0?d:a,T=h!=null&&Rs(h);if(T&&Qi.includes(l))return;let g=re(l,T?Qi.concat(i):i);e.reportError(new f(`Unknown type "${l}".`+Z(g),{nodes:o}))}}}}var Qi=[...er,...ir].map(e=>e.name);function Rs(e){return"kind"in e&&(an(e)||cn(e))}function hn(e){let t=0;return{Document(r){t=r.definitions.filter(n=>n.kind===u.OPERATION_DEFINITION).length},OperationDefinition(r){!r.name&&t>1&&e.reportError(new f("This anonymous operation must be the only defined operation.",{nodes:r}))}}}function yn(e){var t,r,n;let i=e.getSchema(),o=(t=(r=(n=i?.astNode)!==null&&n!==void 0?n:i?.getQueryType())!==null&&r!==void 0?r: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 bs=3;function Tn(e){function t(r,n=Object.create(null),i=0){if(r.kind===u.FRAGMENT_SPREAD){let o=r.name.value;if(n[o]===!0)return!1;let s=e.getFragment(o);if(!s)return!1;try{return n[o]=!0,t(s,n,i)}finally{n[o]=void 0}}if(r.kind===u.FIELD&&(r.name.value==="fields"||r.name.value==="interfaces"||r.name.value==="possibleTypes"||r.name.value==="inputFields")&&(i++,i>=bs))return!0;if("selectionSet"in r&&r.selectionSet){for(let o of r.selectionSet.selections)if(t(o,n,i))return!0}return!1}return{Field(r){if((r.name.value==="__schema"||r.name.value==="__type")&&t(r))return e.reportError(new f("Maximum introspection depth exceeded",{nodes:[r]})),!1}}}function gn(e){let t=Object.create(null),r=[],n=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){n[s]=r.length;for(let c of a){let p=c.name.value,l=n[p];if(r.push(c),l===void 0){let d=e.getFragment(p);d&&i(d)}else{let d=r.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}))}r.pop()}n[s]=void 0}}}function En(e){let t=Object.create(null);return{OperationDefinition:{enter(){t=Object.create(null)},leave(r){let n=e.getRecursiveVariableUsages(r);for(let{node:i}of n){let o=i.name.value;t[o]!==!0&&e.reportError(new f(r.name?`Variable "$${o}" is not defined by operation "${r.name.value}".`:`Variable "$${o}" is not defined.`,{nodes:[i,r]}))}}},VariableDefinition(r){t[r.variable.name.value]=!0}}}function vn(e){let t=[],r=[];return{OperationDefinition(n){return t.push(n),!1},FragmentDefinition(n){return r.push(n),!1},Document:{leave(){let n=Object.create(null);for(let i of t)for(let o of e.getRecursivelyReferencedFragments(i))n[o.name.value]=!0;for(let i of r){let o=i.name.value;n[o]!==!0&&e.reportError(new f(`Fragment "${o}" is never used.`,{nodes:i}))}}}}}function Nn(e){let t=[];return{OperationDefinition:{enter(){t=[]},leave(r){let n=Object.create(null),i=e.getRecursiveVariableUsages(r);for(let{node:o}of i)n[o.name.value]=!0;for(let o of t){let s=o.variable.name.value;n[s]!==!0&&e.reportError(new f(r.name?`Variable "$${s}" is never used in operation "${r.name.value}".`:`Variable "$${s}" is never used.`,{nodes:o}))}}},VariableDefinition(r){t.push(r)}}}function pr(e){switch(e.kind){case u.OBJECT:return{...e,fields:Os(e.fields)};case u.LIST:return{...e,values:e.values.map(pr)};case u.INT:case u.FLOAT:case u.STRING:case u.BOOLEAN:case u.NULL:case u.ENUM:case u.VARIABLE:return e}}function Os(e){return e.map(t=>({...t,value:pr(t.value)})).sort((t,r)=>Xe(t.name.value,r.name.value))}function qi(e){return Array.isArray(e)?e.map(([t,r])=>`subfields "${t}" conflict because `+qi(r)).join(" and "):e}function On(e){let t=new mr,r=new bn,n=new Map;return{SelectionSet(i){let o=Ss(e,n,t,r,e.getParentType(),i);for(let[[s,a],c,p]of o){let l=qi(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 Ss(e,t,r,n,i,o){let s=[],[a,c]=dr(e,t,i,o);if(xs(e,s,t,r,n,a),c.length!==0)for(let p=0;p<c.length;p++){lr(e,s,t,r,n,!1,a,c[p]);for(let l=p+1;l<c.length;l++)fr(e,s,t,r,n,!1,c[p],c[l])}return s}function lr(e,t,r,n,i,o,s,a){if(n.has(s,a,o))return;n.add(s,a,o);let c=e.getFragment(a);if(!c)return;let[p,l]=Rn(e,r,c);if(s!==p){Sn(e,t,r,n,i,o,s,p);for(let d of l)lr(e,t,r,n,i,o,s,d)}}function fr(e,t,r,n,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]=Rn(e,r,c),[h,T]=Rn(e,r,p);Sn(e,t,r,n,i,o,l,h);for(let g of T)fr(e,t,r,n,i,o,s,g);for(let g of d)fr(e,t,r,n,i,o,g,a)}function _s(e,t,r,n,i,o,s,a,c){let p=[],[l,d]=dr(e,t,o,s),[h,T]=dr(e,t,a,c);Sn(e,p,t,r,n,i,l,h);for(let g of T)lr(e,p,t,r,n,i,l,g);for(let g of d)lr(e,p,t,r,n,i,h,g);for(let g of d)for(let A of T)fr(e,p,t,r,n,i,g,A);return p}function xs(e,t,r,n,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=Yi(e,r,n,i,!1,s,a[c],a[p]);l&&t.push(l)}}function Sn(e,t,r,n,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=Yi(e,r,n,i,o,c,d,h);T&&t.push(T)}}}function Yi(e,t,r,n,i,o,s,a){let[c,p,l]=s,[d,h,T]=a,g=i||c!==d&&S(c)&&S(d);if(!g){let se=p.name.value,he=h.name.value;if(se!==he)return[[o,`"${se}" and "${he}" are different fields`],[p],[h]];if(!Ls(p,h))return[[o,"they have differing arguments"],[p],[h]]}let A=l?.type,K=T?.type;if(A&&K&&In(A,K))return[[o,`they return conflicting types "${y(A)}" and "${y(K)}"`],[p],[h]];let Y=p.selectionSet,le=h.selectionSet;if(Y&&le){let se=_s(e,t,r,n,g,H(A),Y,H(K),le);return ws(se,o,p,h)}}function Ls(e,t){let r=e.arguments,n=t.arguments;if(r===void 0||r.length===0)return n===void 0||n.length===0;if(n===void 0||n.length===0||r.length!==n.length)return!1;let i=new Map(n.map(({name:o,value:s})=>[o.value,s]));return r.every(o=>{let s=o.value,a=i.get(o.name.value);return a===void 0?!1:Bi(s)===Bi(a)})}function Bi(e){return L(pr(e))}function In(e,t){return w(e)?w(t)?In(e.ofType,t.ofType):!0:w(t)?!0:R(e)?R(t)?In(e.ofType,t.ofType):!0:R(t)?!0:X(e)||X(t)?e!==t:!1}function dr(e,t,r,n){let i=t.get(n);if(i)return i;let o=Object.create(null),s=Object.create(null);Hi(e,r,n,o,s);let a=[o,Object.keys(s)];return t.set(n,a),a}function Rn(e,t,r){let n=t.get(r.selectionSet);if(n)return n;let i=P(e.getSchema(),r.typeCondition);return dr(e,t,i,r.selectionSet)}function Hi(e,t,r,n,i){for(let o of r.selections)switch(o.kind){case u.FIELD:{let s=o.name.value,a;(S(t)||_(t))&&(a=t.getFields()[s]);let c=o.alias?o.alias.value:s;n[c]||(n[c]=[]),n[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?P(e.getSchema(),s):t;Hi(e,a,o.selectionSet,n,i);break}}}function ws(e,t,r,n){if(e.length>0)return[[t,e.map(([i])=>i)],[r,...e.map(([,i])=>i).flat()],[n,...e.map(([,,i])=>i).flat()]]}var mr=class{constructor(){this._data=new Map}has(t,r,n){var i;let o=(i=this._data.get(t))===null||i===void 0?void 0:i.get(r);return o===void 0?!1:n?!0:n===o}add(t,r,n){let i=this._data.get(t);i===void 0?this._data.set(t,new Map([[r,n]])):i.set(r,n)}},bn=class{constructor(){this._orderedPairSet=new mr}has(t,r,n){return t<r?this._orderedPairSet.has(t,r,n):this._orderedPairSet.has(r,t,n)}add(t,r,n){t<r?this._orderedPairSet.add(t,r,n):this._orderedPairSet.add(r,t,n)}};function _n(e){return{InlineFragment(t){let r=e.getType(),n=e.getParentType();if(ce(r)&&ce(n)&&!Jr(e.getSchema(),r,n)){let i=y(n),o=y(r);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 r=t.name.value,n=Ds(e,r),i=e.getParentType();if(n&&i&&!Jr(e.getSchema(),n,i)){let o=y(i),s=y(n);e.reportError(new f(`Fragment "${r}" cannot be spread here as objects of type "${o}" can never be of type "${s}".`,{nodes:t}))}}}}function Ds(e,t){let r=e.getFragment(t);if(r){let n=P(e.getSchema(),r.typeCondition);if(ce(n))return n}}function xn(e){let t=e.getSchema(),r=Object.create(null);for(let i of e.getDocument().definitions)we(i)&&(r[i.name.value]=i);return{ScalarTypeExtension:n,ObjectTypeExtension:n,InterfaceTypeExtension:n,UnionTypeExtension:n,EnumTypeExtension:n,InputObjectTypeExtension:n};function n(i){let o=i.name.value,s=r[o],a=t?.getType(o),c;if(s?c=As[s.kind]:a&&(c=Fs(a)),c){if(c!==i.kind){let p=Cs(i.kind);e.reportError(new f(`Cannot extend non-${p} type "${o}".`,{nodes:s?[s,i]:i}))}}else{let p=Object.keys({...r,...t?.getTypeMap()}),l=re(o,p);e.reportError(new f(`Cannot extend type "${o}" because it is not defined.`+Z(l),{nodes:i.name}))}}}var As={[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 Fs(e){if(Ee(e))return u.SCALAR_TYPE_EXTENSION;if(S(e))return u.OBJECT_TYPE_EXTENSION;if(_(e))return u.INTERFACE_TYPE_EXTENSION;if(J(e))return u.UNION_TYPE_EXTENSION;if(V(e))return u.ENUM_TYPE_EXTENSION;if(x(e))return u.INPUT_OBJECT_TYPE_EXTENSION;k(!1,"Unexpected type: "+y(e))}function Cs(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:k(!1,"Unexpected kind: "+y(e))}}function Ln(e){return{...wn(e),Field:{leave(t){var r;let n=e.getFieldDef();if(!n)return!1;let i=new Set((r=t.arguments)===null||r===void 0?void 0:r.map(o=>o.name.value));for(let o of n.args)if(!i.has(o.name)&&Oe(o)){let s=y(o.type);e.reportError(new f(`Field "${n.name}" argument "${o.name}" of type "${s}" is required, but it was not provided.`,{nodes:t}))}}}}}function wn(e){var t;let r=Object.create(null),n=e.getSchema(),i=(t=n?.getDirectives())!==null&&t!==void 0?t:ve;for(let a of i)r[a.name]=ye(a.args.filter(Oe),c=>c.name);let o=e.getDocument().definitions;for(let a of o)if(a.kind===u.DIRECTIVE_DEFINITION){var s;let c=(s=a.arguments)!==null&&s!==void 0?s:[];r[a.name.value]=ye(c.filter(ks),p=>p.name.value)}return{Directive:{leave(a){let c=a.name.value,p=r[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 A=et(g.type)?y(g.type):L(g.type);e.reportError(new f(`Directive "@${c}" argument "${T}" of type "${A}" is required, but it was not provided.`,{nodes:a}))}}}}}}function ks(e){return e.type.kind===u.NON_NULL_TYPE&&e.defaultValue==null}function Dn(e){return{Field(t){let r=e.getType(),n=t.selectionSet;if(r)if(X(H(r))){if(n){let i=t.name.value,o=y(r);e.reportError(new f(`Field "${i}" must not have a selection since type "${o}" has no subfields.`,{nodes:n}))}}else if(n){if(n.selections.length===0){let i=t.name.value,o=y(r);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(r);e.reportError(new f(`Field "${i}" of type "${o}" must have a selection of subfields. Did you mean "${i} { ... }"?`,{nodes:t}))}}}}function hr(e){return e.map(t=>typeof t=="number"?"["+t.toString()+"]":"."+t).join("")}function Ve(e,t,r){return{prev:e,key:t,typename:r}}function ee(e){let t=[],r=e;for(;r;)t.push(r.key),r=r.prev;return t.reverse()}function Ji(e,t,r=Ms){return wt(e,t,r,void 0)}function Ms(e,t,r){let n="Invalid value "+y(t);throw e.length>0&&(n+=` at "value${hr(e)}"`),r.message=n+": "+r.message,r}function wt(e,t,r,n){if(R(t)){if(e!=null)return wt(e,t.ofType,r,n);r(ee(n),e,new f(`Expected non-nullable type "${y(t)}" not to be null.`));return}if(e==null)return null;if(w(t)){let i=t.ofType;return nt(e)?Array.from(e,(o,s)=>{let a=Ve(n,s,void 0);return wt(o,i,r,a)}):[wt(e,i,r,n)]}if(x(t)){if(!Q(e)||Array.isArray(e)){r(ee(n),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(R(s.type)){let c=y(s.type);r(ee(n),e,new f(`Field "${s.name}" of required type "${c}" was not provided.`))}continue}i[s.name]=wt(a,s.type,r,Ve(n,s.name,t.name))}for(let s of Object.keys(e))if(!o[s]){let a=re(s,Object.keys(t.getFields()));r(ee(n),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&&r(ee(n),e,new f(`Exactly one key must be specified for OneOf type "${t.name}".`));let a=s[0],c=i[a];c===null&&r(ee(n).concat(a),c,new f(`Field "${a}" must be non-null.`))}return i}if(X(t)){let i;try{i=t.parseValue(e)}catch(o){o instanceof f?r(ee(n),e,o):r(ee(n),e,new f(`Expected type "${t.name}". `+o.message,{originalError:o}));return}return i===void 0&&r(ee(n),e,new f(`Expected type "${t.name}".`)),i}k(!1,"Unexpected input type: "+y(t))}function Ge(e,t,r){if(e){if(e.kind===u.VARIABLE){let n=e.name.value;if(r==null||r[n]===void 0)return;let i=r[n];return i===null&&R(t)?void 0:i}if(R(t))return e.kind===u.NULL?void 0:Ge(e,t.ofType,r);if(e.kind===u.NULL)return null;if(w(t)){let n=t.ofType;if(e.kind===u.LIST){let o=[];for(let s of e.values)if(zi(s,r)){if(R(n))return;o.push(null)}else{let a=Ge(s,n,r);if(a===void 0)return;o.push(a)}return o}let i=Ge(e,n,r);return i===void 0?void 0:[i]}if(x(t)){if(e.kind!==u.OBJECT)return;let n=Object.create(null),i=ye(e.fields,o=>o.name.value);for(let o of Object.values(t.getFields())){let s=i[o.name];if(!s||zi(s.value,r)){if(o.defaultValue!==void 0)n[o.name]=o.defaultValue;else if(R(o.type))return;continue}let a=Ge(s.value,o.type,r);if(a===void 0)return;n[o.name]=a}if(t.isOneOf){let o=Object.keys(n);if(o.length!==1||n[o[0]]===null)return}return n}if(X(t)){let n;try{n=t.parseLiteral(e,r)}catch{return}return n===void 0?void 0:n}k(!1,"Unexpected input type: "+y(t))}}function zi(e,t){return e.kind===u.VARIABLE&&(t==null||t[e.name.value]===void 0)}function An(e,t,r,n){let i=[],o=n?.maxErrors;try{let s=Ps(e,t,r,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 Ps(e,t,r,n){let i={};for(let o of t){let s=o.variable.name.value,a=P(e,o.type);if(!z(a)){let p=L(o.type);n(new f(`Variable "$${s}" expected value of type "${p}" which cannot be used as an input type.`,{nodes:o.type}));continue}if(!Xi(r,s)){if(o.defaultValue)i[s]=Ge(o.defaultValue,a);else if(R(a)){let p=y(a);n(new f(`Variable "$${s}" of required type "${p}" was not provided.`,{nodes:o}))}continue}let c=r[s];if(c===null&&R(a)){let p=y(a);n(new f(`Variable "$${s}" of non-null type "${p}" must not be null.`,{nodes:o}));continue}i[s]=Ji(c,a,(p,l,d)=>{let h=`Variable "$${s}" got invalid value `+y(l);p.length>0&&(h+=` at "${s}${hr(p)}"`),n(new f(h+"; "+d.message,{nodes:o,originalError:d}))})}return i}function yr(e,t,r){var n;let i={},o=(n=t.arguments)!==null&&n!==void 0?n:[],s=ye(o,a=>a.name.value);for(let a of e.args){let c=a.name,p=a.type,l=s[c];if(!l){if(a.defaultValue!==void 0)i[c]=a.defaultValue;else if(R(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(r==null||!Xi(r,g)){if(a.defaultValue!==void 0)i[c]=a.defaultValue;else if(R(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=r[g]==null}if(h&&R(p))throw new f(`Argument "${c}" of non-null type "${y(p)}" must not be null.`,{nodes:d});let T=Ge(d,p,r);if(T===void 0)throw new f(`Argument "${c}" has invalid value ${L(d)}.`,{nodes:d});i[c]=T}return i}function Tr(e,t,r){var n;let i=(n=t.directives)===null||n===void 0?void 0:n.find(o=>o.name.value===e.name);if(i)return yr(e,i,r)}function Xi(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function Er(e,t,r,n,i){let o=new Map;return gr(e,t,r,n,i,o,new Set),o}function Wi(e,t,r,n,i){let o=new Map,s=new Set;for(let a of i)a.selectionSet&&gr(e,t,r,n,a.selectionSet,o,s);return o}function gr(e,t,r,n,i,o,s){for(let a of i.selections)switch(a.kind){case u.FIELD:{if(!Fn(r,a))continue;let c=Us(a),p=o.get(c);p!==void 0?p.push(a):o.set(c,[a]);break}case u.INLINE_FRAGMENT:{if(!Fn(r,a)||!Ki(e,a,n))continue;gr(e,t,r,n,a.selectionSet,o,s);break}case u.FRAGMENT_SPREAD:{let c=a.name.value;if(s.has(c)||!Fn(r,a))continue;s.add(c);let p=t[c];if(!p||!Ki(e,p,n))continue;gr(e,t,r,n,p.selectionSet,o,s);break}}}function Fn(e,t){let r=Tr(rr,t,e);if(r?.if===!0)return!1;let n=Tr(tr,t,e);return n?.if!==!1}function Ki(e,t,r){let n=t.typeCondition;if(!n)return!0;let i=P(e,n);return i===r?!0:ie(i)?e.isSubType(i,r):!1}function Us(e){return e.alias?e.alias.value:e.name.value}function Cn(e){return{OperationDefinition(t){if(t.operation==="subscription"){let r=e.getSchema(),n=r.getSubscriptionType();if(n){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=Er(r,a,o,n,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 st(e,t){let r=new Map;for(let n of e){let i=t(n),o=r.get(i);o===void 0?r.set(i,[n]):o.push(n)}return r}function kn(e){return{DirectiveDefinition(n){var i;let o=(i=n.arguments)!==null&&i!==void 0?i:[];return r(`@${n.name.value}`,o)},InterfaceTypeDefinition:t,InterfaceTypeExtension:t,ObjectTypeDefinition:t,ObjectTypeExtension:t};function t(n){var i;let o=n.name.value,s=(i=n.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:[];r(`${o}.${p}`,l)}return!1}function r(n,i){let o=st(i,s=>s.name.value);for(let[s,a]of o)a.length>1&&e.reportError(new f(`Argument "${n}(${s}:)" can only be defined once.`,{nodes:a.map(c=>c.name)}));return!1}}function vr(e){return{Field:t,Directive:t};function t(r){var n;let i=(n=r.arguments)!==null&&n!==void 0?n:[],o=st(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 Mn(e){let t=Object.create(null),r=e.getSchema();return{DirectiveDefinition(n){let i=n.name.value;if(r!=null&&r.getDirective(i)){e.reportError(new f(`Directive "@${i}" already exists in the schema. It cannot be redefined.`,{nodes:n.name}));return}return t[i]?e.reportError(new f(`There can be only one directive named "@${i}".`,{nodes:[t[i],n.name]})):t[i]=n.name,!1}}}function Nr(e){let t=Object.create(null),r=e.getSchema(),n=r?r.getDirectives():ve;for(let a of n)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(we(a)||ar(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 Pn(e){let t=e.getSchema(),r=t?t.getTypeMap():Object.create(null),n=Object.create(null);return{EnumTypeDefinition:i,EnumTypeExtension:i};function i(o){var s;let a=o.name.value;n[a]||(n[a]=Object.create(null));let c=(s=o.values)!==null&&s!==void 0?s:[],p=n[a];for(let l of c){let d=l.name.value,h=r[a];V(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 Un(e){let t=e.getSchema(),r=t?t.getTypeMap():Object.create(null),n=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;n[a]||(n[a]=Object.create(null));let c=(s=o.fields)!==null&&s!==void 0?s:[],p=n[a];for(let l of c){let d=l.name.value;$s(r[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 $s(e,t){return S(e)||_(e)||x(e)?e.getFields()[t]!=null:!1}function $n(e){let t=Object.create(null);return{OperationDefinition:()=>!1,FragmentDefinition(r){let n=r.name.value;return t[n]?e.reportError(new f(`There can be only one fragment named "${n}".`,{nodes:[t[n],r.name]})):t[n]=r.name,!1}}}function Ir(e){let t=[],r=Object.create(null);return{ObjectValue:{enter(){t.push(r),r=Object.create(null)},leave(){let n=t.pop();n||k(!1),r=n}},ObjectField(n){let i=n.name.value;r[i]?e.reportError(new f(`There can be only one input field named "${i}".`,{nodes:[r[i],n.name]})):r[i]=n.name}}}function Vn(e){let t=Object.create(null);return{OperationDefinition(r){let n=r.name;return n&&(t[n.value]?e.reportError(new f(`There can be only one operation named "${n.value}".`,{nodes:[t[n.value],n]})):t[n.value]=n),!1},FragmentDefinition:()=>!1}}function Gn(e){let t=e.getSchema(),r=Object.create(null),n=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=r[p];n[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]})):r[p]=c}return!1}}function jn(e){let t=Object.create(null),r=e.getSchema();return{ScalarTypeDefinition:n,ObjectTypeDefinition:n,InterfaceTypeDefinition:n,UnionTypeDefinition:n,EnumTypeDefinition:n,InputObjectTypeDefinition:n};function n(i){let o=i.name.value;if(r!=null&&r.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 Qn(e){return{OperationDefinition(t){var r;let n=(r=t.variableDefinitions)!==null&&r!==void 0?r:[],i=st(n,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 Bn(e){let t={};return{OperationDefinition:{enter(){t={}}},VariableDefinition(r){t[r.variable.name.value]=r},ListValue(r){let n=tt(e.getParentInputType());if(!w(n))return je(e,r),!1},ObjectValue(r){let n=H(e.getInputType());if(!x(n))return je(e,r),!1;let i=ye(r.fields,o=>o.name.value);for(let o of Object.values(n.getFields()))if(!i[o.name]&&rt(o)){let a=y(o.type);e.reportError(new f(`Field "${n.name}.${o.name}" of required type "${a}" was not provided.`,{nodes:r}))}n.isOneOf&&Vs(e,r,n,i)},ObjectField(r){let n=H(e.getParentInputType());if(!e.getInputType()&&x(n)){let o=re(r.name.value,Object.keys(n.getFields()));e.reportError(new f(`Field "${r.name.value}" is not defined by type "${n.name}".`+Z(o),{nodes:r}))}},NullValue(r){let n=e.getInputType();R(n)&&e.reportError(new f(`Expected value of type "${y(n)}", found ${L(r)}.`,{nodes:r}))},EnumValue:r=>je(e,r),IntValue:r=>je(e,r),FloatValue:r=>je(e,r),StringValue:r=>je(e,r),BooleanValue:r=>je(e,r)}}function je(e,t){let r=e.getInputType();if(!r)return;let n=H(r);if(!X(n)){let i=y(r);e.reportError(new f(`Expected value of type "${i}", found ${L(t)}.`,{nodes:t}));return}try{if(n.parseLiteral(t,void 0)===void 0){let o=y(r);e.reportError(new f(`Expected value of type "${o}", found ${L(t)}.`,{nodes:t}))}}catch(i){let o=y(r);i instanceof f?e.reportError(i):e.reportError(new f(`Expected value of type "${o}", found ${L(t)}; `+i.message,{nodes:t,originalError:i}))}}function Vs(e,t,r,n){var i;let o=Object.keys(n);if(o.length!==1){e.reportError(new f(`OneOf Input Object "${r.name}" must specify exactly one key.`,{nodes:[t]}));return}let a=(i=n[o[0]])===null||i===void 0?void 0:i.value;(!a||a.kind===u.NULL)&&e.reportError(new f(`Field "${r.name}.${o[0]}" must be non-null.`,{nodes:[t]}))}function qn(e){return{VariableDefinition(t){let r=P(e.getSchema(),t.type);if(r!==void 0&&!z(r)){let n=t.variable.name.value,i=L(t.type);e.reportError(new f(`Variable "$${n}" cannot be non-input type "${i}".`,{nodes:t.type}))}}}}function Yn(e){let t=Object.create(null);return{OperationDefinition:{enter(){t=Object.create(null)},leave(r){let n=e.getRecursiveVariableUsages(r);for(let{node:i,type:o,defaultValue:s,parentType:a}of n){let c=i.name.value,p=t[c];if(p&&o){let l=e.getSchema(),d=P(l,p.type);if(d&&!Gs(l,d,p.defaultValue,o,s)){let h=y(d),T=y(o);e.reportError(new f(`Variable "$${c}" of type "${h}" used in position expecting type "${T}".`,{nodes:[p,i]}))}x(a)&&a.isOneOf&&Nt(d)&&e.reportError(new f(`Variable "$${c}" is of type "${d}" but must be non-nullable to be used for OneOf Input Object "${a}".`,{nodes:[p,i]}))}}}},VariableDefinition(r){t[r.variable.name.value]=r}}}function Gs(e,t,r,n,i){if(R(n)&&!R(t)){if(!(r!=null&&r.kind!==u.NULL)&&!(i!==void 0))return!1;let a=n.ofType;return Le(e,t,a)}return Le(e,t,n)}var Hn=Object.freeze([Tn]),at=Object.freeze([un,Vn,hn,Cn,ur,ln,qn,Dn,pn,$n,mn,vn,_n,gn,Qn,En,Nn,cr,Nr,fn,vr,Bn,Ln,Yn,On,Ir,...Hn]),js=Object.freeze([yn,Gn,jn,Pn,Un,kn,Mn,ur,cr,Nr,xn,dn,vr,Ir,wn]);var Jn=class{constructor(t,r){this._ast=t,this._fragments=void 0,this._fragmentSpreads=new Map,this._recursivelyReferencedFragments=new Map,this._onError=r}get[Symbol.toStringTag](){return"ASTValidationContext"}reportError(t){this._onError(t)}getDocument(){return this._ast}getFragment(t){let r;if(this._fragments)r=this._fragments;else{r=Object.create(null);for(let n of this.getDocument().definitions)n.kind===u.FRAGMENT_DEFINITION&&(r[n.name.value]=n);this._fragments=r}return r[t]}getFragmentSpreads(t){let r=this._fragmentSpreads.get(t);if(!r){r=[];let n=[t],i;for(;i=n.pop();)for(let o of i.selections)o.kind===u.FRAGMENT_SPREAD?r.push(o):o.selectionSet&&n.push(o.selectionSet);this._fragmentSpreads.set(t,r)}return r}getRecursivelyReferencedFragments(t){let r=this._recursivelyReferencedFragments.get(t);if(!r){r=[];let n=Object.create(null),i=[t.selectionSet],o;for(;o=i.pop();)for(let s of this.getFragmentSpreads(o)){let a=s.name.value;if(n[a]!==!0){n[a]=!0;let c=this.getFragment(a);c&&(r.push(c),i.push(c.selectionSet))}}this._recursivelyReferencedFragments.set(t,r)}return r}};var Dt=class extends Jn{constructor(t,r,n,i){super(r,i),this._schema=t,this._typeInfo=n,this._variableUsages=new Map,this._recursiveVariableUsages=new Map}get[Symbol.toStringTag](){return"ValidationContext"}getSchema(){return this._schema}getVariableUsages(t){let r=this._variableUsages.get(t);if(!r){let n=[],i=new ot(this._schema);Fe(t,sr(i,{VariableDefinition:()=>!1,Variable(o){n.push({node:o,type:i.getInputType(),defaultValue:i.getDefaultValue(),parentType:i.getParentInputType()})}})),r=n,this._variableUsages.set(t,r)}return r}getRecursiveVariableUsages(t){let r=this._recursiveVariableUsages.get(t);if(!r){r=this.getVariableUsages(t);for(let n of this.getRecursivelyReferencedFragments(t))r=r.concat(this.getVariableUsages(n));this._recursiveVariableUsages.set(t,r)}return r}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()}};var Qs=Ae(dt,e=>e.filter(t=>t!=="description"));function Rr(e,t,r=at,n,i=new ot(e)){var o;let s=(o=n?.maxErrors)!==null&&o!==void 0?o:100;t||O(!1,"Must provide document."),Lt(e);let a=Object.freeze({}),c=[],p=new Dt(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=Qr(r.map(d=>d(p)));try{Fe(t,sr(i,l),Qs)}catch(d){if(d!==a)throw d}return c}function Zi(e){let t;return function(n,i,o){t===void 0&&(t=new WeakMap);let s=t.get(n);s===void 0&&(s=new WeakMap,t.set(n,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(n,i,o),a.set(o,c)),c}}function zn(e){return Promise.all(Object.values(e)).then(t=>{let r=Object.create(null);for(let[n,i]of Object.keys(e).entries())r[i]=t[n];return r})}function eo(e,t,r){let n=r;for(let i of e)n=ae(n)?n.then(o=>t(o,i)):t(n,i);return n}function to(e){return e instanceof Error?e:new Xn(e)}var Xn=class extends Error{constructor(t){super("Unexpected error value: "+y(t)),this.name="NonErrorThrown",this.thrownValue=t}};function At(e,t,r){var n;let i=to(e);return Bs(i)?i:new f(i.message,{nodes:(n=i.nodes)!==null&&n!==void 0?n:t,source:i.source,positions:i.positions,path:r,originalError:i})}function Bs(e){return Array.isArray(e.path)}var qs=Zi((e,t,r)=>Wi(e.schema,e.fragments,e.variableValues,t,r)),Kn=class{constructor(){this._errorPositions=new Set,this._errors=[]}get errors(){return this._errors}add(t,r){this._hasNulledPosition(r)||(this._errorPositions.add(r),this._errors.push(t))}_hasNulledPosition(t){let r=t;for(;r!==void 0;){if(this._errorPositions.has(r))return!0;r=r.prev}return this._errorPositions.has(void 0)}};function xr(e){arguments.length<2||O(!1,"graphql@16 dropped long-deprecated support for positional arguments, please pass an object instead.");let{schema:t,document:r,variableValues:n,rootValue:i}=e;Ys(t,r,n);let o=Hs(e);if(!("schema"in o))return{errors:o};try{let{operation:s}=o,a=Js(o,s,i);return ae(a)?a.then(c=>br(c,o.collectedErrors.errors),c=>(o.collectedErrors.add(c,void 0),br(null,o.collectedErrors.errors))):br(a,o.collectedErrors.errors)}catch(s){return o.collectedErrors.add(s,void 0),br(null,o.collectedErrors.errors)}}function br(e,t){return t.length===0?{data:e}:{errors:t,data:e}}function Ys(e,t,r){t||O(!1,"Must provide document."),Lt(e),r==null||Q(r)||O(!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 Hs(e){var t,r,n;let{schema:i,document:o,rootValue:s,contextValue:a,variableValues:c,operationName:p,fieldResolver:l,typeResolver:d,subscribeFieldResolver:h,options:T}=e,g,A=Object.create(null);for(let le of o.definitions)switch(le.kind){case u.OPERATION_DEFINITION:if(p==null){if(g!==void 0)return[new f("Must provide operation name if query contains multiple operations.")];g=le}else((t=le.name)===null||t===void 0?void 0:t.value)===p&&(g=le);break;case u.FRAGMENT_DEFINITION:A[le.name.value]=le;break;default:}if(!g)return p!=null?[new f(`Unknown operation named "${p}".`)]:[new f("Must provide an operation.")];let K=(r=g.variableDefinitions)!==null&&r!==void 0?r:[],Y=An(i,K,c??{},{maxErrors:(n=T?.maxCoercionErrors)!==null&&n!==void 0?n:50});return Y.errors?Y.errors:{schema:i,fragments:A,rootValue:s,contextValue:a,operation:g,variableValues:Y.coerced,fieldResolver:l??_r,typeResolver:d??Zn,subscribeFieldResolver:h??_r,collectedErrors:new Kn}}function Js(e,t,r){let n=e.schema.getRootType(t.operation);if(n==null)throw new f(`Schema is not configured to execute ${t.operation} operation.`,{nodes:t});let i=Er(e.schema,e.fragments,e.variableValues,n,t.selectionSet),o=void 0;switch(t.operation){case C.QUERY:return Or(e,n,r,o,i);case C.MUTATION:return zs(e,n,r,o,i);case C.SUBSCRIPTION:return Or(e,n,r,o,i)}}function zs(e,t,r,n,i){return eo(i.entries(),(o,[s,a])=>{let c=Ve(n,s,t.name),p=io(e,t,r,a,c);return p===void 0?o:ae(p)?p.then(l=>(o[s]=l,o)):(o[s]=p,o)},Object.create(null))}function Or(e,t,r,n,i){let o=Object.create(null),s=!1;try{for(let[a,c]of i.entries()){let p=Ve(n,a,t.name),l=io(e,t,r,c,p);l!==void 0&&(o[a]=l,ae(l)&&(s=!0))}}catch(a){if(s)return zn(o).finally(()=>{throw a});throw a}return s?zn(o):o}function io(e,t,r,n,i){var o;let s=ea(e.schema,t,n[0]);if(!s)return;let a=s.type,c=(o=s.resolve)!==null&&o!==void 0?o:e.fieldResolver,p=Xs(e,s,n,t,i);try{let l=yr(s,n[0],e.variableValues),d=e.contextValue,h=c(r,l,d,p),T;return ae(h)?T=h.then(g=>Ft(e,a,n,p,i,g)):T=Ft(e,a,n,p,i,h),ae(T)?T.then(void 0,g=>{let A=At(g,n,ee(i));return Sr(A,a,i,e)}):T}catch(l){let d=At(l,n,ee(i));return Sr(d,a,i,e)}}function Xs(e,t,r,n,i){return{fieldName:t.name,fieldNodes:r,returnType:t.type,parentType:n,path:i,schema:e.schema,fragments:e.fragments,rootValue:e.rootValue,operation:e.operation,variableValues:e.variableValues}}function Sr(e,t,r,n){if(R(t))throw e;return n.collectedErrors.add(e,r),null}function Ft(e,t,r,n,i,o){if(o instanceof Error)throw o;if(R(t)){let s=Ft(e,t.ofType,r,n,i,o);if(s===null)throw new Error(`Cannot return null for non-nullable field ${n.parentType.name}.${n.fieldName}.`);return s}if(o==null)return null;if(w(t))return Ks(e,t,r,n,i,o);if(X(t))return Ws(t,o);if(ie(t))return Zs(e,t,r,n,i,o);if(S(t))return Wn(e,t,r,n,i,o);k(!1,"Cannot complete value of unexpected output type: "+y(t))}function Ks(e,t,r,n,i,o){if(!nt(o))throw new f(`Expected Iterable, but did not find one for field "${n.parentType.name}.${n.fieldName}".`);let s=t.ofType,a=!1,c=Array.from(o,(p,l)=>{let d=Ve(i,l,void 0);try{let h;return ae(p)?h=p.then(T=>Ft(e,s,r,n,d,T)):h=Ft(e,s,r,n,d,p),ae(h)?(a=!0,h.then(void 0,T=>{let g=At(T,r,ee(d));return Sr(g,s,d,e)})):h}catch(h){let T=At(h,r,ee(d));return Sr(T,s,d,e)}});return a?Promise.all(c):c}function Ws(e,t){let r=e.serialize(t);if(r==null)throw new Error(`Expected \`${y(e)}.serialize(${y(t)})\` to return non-nullable value, returned: ${y(r)}`);return r}function Zs(e,t,r,n,i,o){var s;let a=(s=t.resolveType)!==null&&s!==void 0?s:e.typeResolver,c=e.contextValue,p=a(o,c,n,t);return ae(p)?p.then(l=>Wn(e,ro(l,e,t,r,n,o),r,n,i,o)):Wn(e,ro(p,e,t,r,n,o),r,n,i,o)}function ro(e,t,r,n,i,o){if(e==null)throw new f(`Abstract type "${r.name}" must resolve to an Object type at runtime for field "${i.parentType.name}.${i.fieldName}". Either the "${r.name}" type should provide a "resolveType" function or each possible type should provide an "isTypeOf" function.`,n);if(S(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 "${r.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 "${r.name}" was resolved to a type "${e}" that does not exist inside the schema.`,{nodes:n});if(!S(s))throw new f(`Abstract type "${r.name}" was resolved to a non-object type "${e}".`,{nodes:n});if(!t.schema.isSubType(r,s))throw new f(`Runtime Object type "${s.name}" is not a possible type for "${r.name}".`,{nodes:n});return s}function Wn(e,t,r,n,i,o){let s=qs(e,t,r);if(t.isTypeOf){let a=t.isTypeOf(o,e.contextValue,n);if(ae(a))return a.then(c=>{if(!c)throw no(t,o,r);return Or(e,t,o,i,s)});if(!a)throw no(t,o,r)}return Or(e,t,o,i,s)}function no(e,t,r){return new f(`Expected value of type "${e.name}" but got: ${y(t)}.`,{nodes:r})}var Zn=function(e,t,r,n){if(Q(e)&&typeof e.__typename=="string")return e.__typename;let i=r.schema.getPossibleTypes(n),o=[];for(let s=0;s<i.length;s++){let a=i[s];if(a.isTypeOf){let c=a.isTypeOf(e,t,r);if(ae(c))o[s]=c;else if(c)return o.length&&Promise.allSettled(o).catch(()=>{}),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})},_r=function(e,t,r,n){if(Q(e)||typeof e=="function"){let i=e[n.fieldName];return typeof i=="function"?e[n.fieldName](t,r,n):i}};function ea(e,t,r){let n=r.name.value;return n===ke.name&&e.getQueryType()===t?ke:n===Me.name&&e.getQueryType()===t?Me:n===Pe.name?Pe:t.getFields()[n]}import{EMPTY as oo,OperationOutcomeError as j,Operator as ba,allOk as so,badRequest as _e,created as ao,deepClone as Ct,evalFhirPath as co,generateId as uo,globalSchema as Oa,matchesSearchRequest as Sa,multipleMatches as Lr,normalizeOperationOutcome as _a,notFound as kt,preconditionFailed as xa,stringify as La}from"@medplum/core";import{applyPatch as wa}from"rfc6902";var wr={READER:"reader",WRITER:"writer"},ei=class{async searchOne(t){return(await this.search({...t,count:1})).entry?.[0]?.resource}async searchResources(t){return(await this.search(t)).entry?.map(n=>n.resource)??[]}async conditionalCreate(t,r,n){if(r.resourceType!==t.resourceType)throw new j(_e("Search type must match resource type for conditional update"));return r.count=2,r.sortRules=void 0,this.withTransaction(async()=>{let i=await this.searchResources(r);if(i.length===1){let s=i[0];if(!n?.assignedId&&t.id&&t.id!==s.id)throw new j(_e("Resource ID did not match resolved ID",t.resourceType+".id"));return{resource:i[0],outcome:so}}else if(i.length>1)throw new j(Lr);return{resource:await this.createResource(t,n),outcome:ao}},{serializable:!0})}async conditionalUpdate(t,r,n){if(r.resourceType!==t.resourceType)throw new j(_e("Search type must match resource type for conditional update"));return r.count=2,r.sortRules=void 0,this.withTransaction(async()=>{let i=await this.searchResources(r);if(i.length===0){if(t.id&&!n?.assignedId)throw new j(_e("Cannot perform create as update with client-assigned ID",t.resourceType+".id"));return{resource:await this.createResource(t,n),outcome:ao}}else if(i.length>1)throw new j(Lr);let o=i[0];if(t.id&&t.id!==o.id)throw new j(_e("Resource ID did not match resolved ID",t.resourceType+".id"));return{resource:await this.updateResource({...t,id:o.id},n),outcome:so}},{serializable:!0})}async conditionalDelete(t){t.count=2,t.sortRules=void 0,await this.withTransaction(async()=>{let r=await this.searchResources(t);if(r.length>1)throw new j(Lr);if(!r.length)return;let n=r[0];await this.deleteResource(n.resourceType,n.id)},{serializable:!0})}async conditionalPatch(t,r){return t.count=2,t.sortRules=void 0,this.withTransaction(async()=>{let n=await this.searchResources(t);if(n.length>1)throw new j(Lr);if(!n.length)throw new j(kt);let i=n[0];return this.patchResource(i.resourceType,i.id,r)},{serializable:!0})}},po=class extends ei{constructor(){super();F(this,"resources");F(this,"history");F(this,"seeding");this.resources=new Map,this.history=new Map,this.seeding=!1}async withSeeding(r){if(this.seeding)return r();this.seeding=!0;let n=await r();return this.seeding=!1,n}clear(){this.resources.clear(),this.history.clear()}setMode(r){}async createResource(r,n,i=!1){let o=JSON.parse(La(r)),s={...o,id:o.id??this.generateId(),meta:o.meta??{}};this.seeding||(s.meta.versionId&&delete s.meta.versionId,s.meta.lastUpdated&&delete s.meta.lastUpdated),s.meta.versionId??=uo(),s.meta.lastUpdated??=new Date().toISOString();let{resourceType:a,id:c}=s,p=this.resources.get(a);if(p||(p=new Map,this.resources.set(a,p)),!i&&p.has(c))throw new j(_e("Assigned ID is already in use"));p.set(c,s);let l=this.history.get(a);l||(l=new Map,this.history.set(a,l));let d=l.get(c);return d||(d=[],l.set(c,d)),d.push(s),Ct(s)}generateId(){return uo()}updateResource(r,n){if(!r.id)throw new j(_e("Missing id"));if(n?.ifMatch){let i=n.ifMatch,o=this.resources.get(r.resourceType)?.get(r.id);if(!o)throw new j(kt);if(o.meta?.versionId!==i)throw new j(xa)}return this.createResource(r,void 0,!0)}async patchResource(r,n,i){let o=await this.readResource(r,n);try{let s=wa(o,i).filter(Boolean);if(s.length>0)throw new j(_e(s.map(a=>a.message).join(`
|
|
59
|
+
`))}var nn=class{constructor(t){this._errors=[],this.schema=t}reportError(t,r){let n=Array.isArray(r)?r.filter(Boolean):r;this._errors.push(new f(t,{nodes:n}))}getErrors(){return this._errors}};function cs(e){let t=e.schema,r=t.getQueryType();if(!r)e.reportError("Query root type must be provided.",t.astNode);else if(!S(r)){var n;e.reportError(`Query root type must be Object type, it cannot be ${y(r)}.`,(n=rn(t,C.QUERY))!==null&&n!==void 0?n:r.astNode)}let i=t.getMutationType();if(i&&!S(i)){var o;e.reportError(`Mutation root type must be Object type if provided, it cannot be ${y(i)}.`,(o=rn(t,C.MUTATION))!==null&&o!==void 0?o:i.astNode)}let s=t.getSubscriptionType();if(s&&!S(s)){var a;e.reportError(`Subscription root type must be Object type if provided, it cannot be ${y(s)}.`,(a=rn(t,C.SUBSCRIPTION))!==null&&a!==void 0?a:s.astNode)}}function rn(e,t){var r;return(r=[e.astNode,...e.extensionASTNodes].flatMap(n=>{var i;return(i=n?.operationTypes)!==null&&i!==void 0?i:[]}).find(n=>n.operation===t))===null||r===void 0?void 0:r.type}function us(e){for(let r of e.schema.getDirectives()){if(!Ot(r)){e.reportError(`Expected directive but got: ${y(r)}.`,r?.astNode);continue}$e(e,r),r.locations.length===0&&e.reportError(`Directive @${r.name} must include 1 or more locations.`,r.astNode);for(let n of r.args)if($e(e,n),z(n.type)||e.reportError(`The type of @${r.name}(${n.name}:) must be Input Type but got: ${y(n.type)}.`,n.astNode),Oe(n)&&n.deprecationReason!=null){var t;e.reportError(`Required argument @${r.name}(${n.name}:) cannot be deprecated.`,[on(n.astNode),(t=n.astNode)===null||t===void 0?void 0:t.type])}}}function $e(e,t){t.name.startsWith("__")&&e.reportError(`Name "${t.name}" must not begin with "__", which is reserved by GraphQL introspection.`,t.astNode)}function ps(e){let t=Ts(e),r=e.schema.getTypeMap();for(let n of Object.values(r)){if(!Xt(n)){e.reportError(`Expected GraphQL named type but got: ${y(n)}.`,n.astNode);continue}en(n)||$e(e,n),S(n)||_(n)?($i(e,n),Vi(e,n)):J(n)?ds(e,n):V(n)?ms(e,n):x(n)&&(hs(e,n),t(n))}}function $i(e,t){let r=Object.values(t.getFields());r.length===0&&e.reportError(`Type ${t.name} must define one or more fields.`,[t.astNode,...t.extensionASTNodes]);for(let s of r){if($e(e,s),!be(s.type)){var n;e.reportError(`The type of ${t.name}.${s.name} must be Output Type but got: ${y(s.type)}.`,(n=s.astNode)===null||n===void 0?void 0:n.type)}for(let a of s.args){let c=a.name;if($e(e,a),!z(a.type)){var i;e.reportError(`The type of ${t.name}.${s.name}(${c}:) must be Input Type but got: ${y(a.type)}.`,(i=a.astNode)===null||i===void 0?void 0:i.type)}if(Oe(a)&&a.deprecationReason!=null){var o;e.reportError(`Required argument ${t.name}.${s.name}(${c}:) cannot be deprecated.`,[on(a.astNode),(o=a.astNode)===null||o===void 0?void 0:o.type])}}}}function Vi(e,t){let r=Object.create(null);for(let n of t.getInterfaces()){if(!_(n)){e.reportError(`Type ${y(t)} must only implement Interface types, it cannot implement ${y(n)}.`,xt(t,n));continue}if(t===n){e.reportError(`Type ${t.name} cannot implement itself because it would create a circular reference.`,xt(t,n));continue}if(r[n.name]){e.reportError(`Type ${t.name} can only implement ${n.name} once.`,xt(t,n));continue}r[n.name]=!0,fs(e,t,n),ls(e,t,n)}}function ls(e,t,r){let n=t.getFields();for(let c of Object.values(r.getFields())){let p=c.name,l=n[p];if(!l){e.reportError(`Interface field ${r.name}.${p} expected but ${t.name} does not provide it.`,[c.astNode,t.astNode,...t.extensionASTNodes]);continue}if(!Le(e.schema,l.type,c.type)){var i,o;e.reportError(`Interface field ${r.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 ${r.name}.${p}(${h}:) expected but ${t.name}.${p} does not provide it.`,[d.astNode,l.astNode]);continue}if(!Zt(d.type,T.type)){var s,a;e.reportError(`Interface field argument ${r.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)&&Oe(d)&&e.reportError(`Object field ${t.name}.${p} includes required argument ${h} that is missing from the Interface field ${r.name}.${p}.`,[d.astNode,c.astNode])}}}function fs(e,t,r){let n=t.getInterfaces();for(let i of r.getInterfaces())n.includes(i)||e.reportError(i===t?`Type ${t.name} cannot implement ${r.name} because it would create a circular reference.`:`Type ${t.name} must implement ${i.name} because it is implemented by ${r.name}.`,[...xt(r,i),...xt(t,r)])}function ds(e,t){let r=t.getTypes();r.length===0&&e.reportError(`Union type ${t.name} must define one or more member types.`,[t.astNode,...t.extensionASTNodes]);let n=Object.create(null);for(let i of r){if(n[i.name]){e.reportError(`Union type ${t.name} can only include type ${i.name} once.`,Gi(t,i.name));continue}n[i.name]=!0,S(i)||e.reportError(`Union type ${t.name} can only include Object types, it cannot include ${y(i)}.`,Gi(t,String(i)))}}function ms(e,t){let r=t.getValues();r.length===0&&e.reportError(`Enum type ${t.name} must define one or more values.`,[t.astNode,...t.extensionASTNodes]);for(let n of r)$e(e,n)}function hs(e,t){let r=Object.values(t.getFields());r.length===0&&e.reportError(`Input Object type ${t.name} must define one or more fields.`,[t.astNode,...t.extensionASTNodes]);for(let o of r){if($e(e,o),!z(o.type)){var n;e.reportError(`The type of ${t.name}.${o.name} must be Input Type but got: ${y(o.type)}.`,(n=o.astNode)===null||n===void 0?void 0:n.type)}if(rt(o)&&o.deprecationReason!=null){var i;e.reportError(`Required input field ${t.name}.${o.name} cannot be deprecated.`,[on(o.astNode),(i=o.astNode)===null||i===void 0?void 0:i.type])}t.isOneOf&&ys(t,o,e)}}function ys(e,t,r){if(R(t.type)){var n;r.reportError(`OneOf input field ${e.name}.${t.name} must be nullable.`,(n=t.astNode)===null||n===void 0?void 0:n.type)}t.defaultValue!==void 0&&r.reportError(`OneOf input field ${e.name}.${t.name} cannot have a default value.`,t.astNode)}function Ts(e){let t=Object.create(null),r=[],n=Object.create(null);return i;function i(o){if(t[o.name])return;t[o.name]=!0,n[o.name]=r.length;let s=Object.values(o.getFields());for(let a of s)if(R(a.type)&&x(a.type.ofType)){let c=a.type.ofType,p=n[c.name];if(r.push(a),p===void 0)i(c);else{let l=r.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))}r.pop()}n[o.name]=void 0}}function xt(e,t){let{astNode:r,extensionASTNodes:n}=e;return(r!=null?[r,...n]:n).flatMap(o=>{var s;return(s=o.interfaces)!==null&&s!==void 0?s:[]}).filter(o=>o.name.value===t.name)}function Gi(e,t){let{astNode:r,extensionASTNodes:n}=e;return(r!=null?[r,...n]:n).flatMap(o=>{var s;return(s=o.types)!==null&&s!==void 0?s:[]}).filter(o=>o.name.value===t)}function on(e){var t;return e==null||(t=e.directives)===null||t===void 0?void 0:t.find(r=>r.name.value===nr.name)}function P(e,t){switch(t.kind){case u.LIST_TYPE:{let r=P(e,t.type);return r&&new D(r)}case u.NON_NULL_TYPE:{let r=P(e,t.type);return r&&new N(r)}case u.NAMED_TYPE:return e.getType(t.name.value)}}var ot=class{constructor(t,r,n){this._schema=t,this._typeStack=[],this._parentTypeStack=[],this._inputTypeStack=[],this._fieldDefStack=[],this._defaultValueStack=[],this._directive=null,this._argument=null,this._enumValue=null,this._getFieldDef=n??gs,r&&(z(r)&&this._inputTypeStack.push(r),ce(r)&&this._parentTypeStack.push(r),be(r)&&this._typeStack.push(r))}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 r=this._schema;switch(t.kind){case u.SELECTION_SET:{let i=H(this.getType());this._parentTypeStack.push(ce(i)?i:void 0);break}case u.FIELD:{let i=this.getParentType(),o,s;i&&(o=this._getFieldDef(r,i,t),o&&(s=o.type)),this._fieldDefStack.push(o),this._typeStack.push(be(s)?s:void 0);break}case u.DIRECTIVE:this._directive=r.getDirective(t.name.value);break;case u.OPERATION_DEFINITION:{let i=r.getRootType(t.operation);this._typeStack.push(S(i)?i:void 0);break}case u.INLINE_FRAGMENT:case u.FRAGMENT_DEFINITION:{let i=t.typeCondition,o=i?P(r,i):H(this.getType());this._typeStack.push(be(o)?o:void 0);break}case u.VARIABLE_DEFINITION:{let i=P(r,t.type);this._inputTypeStack.push(z(i)?i:void 0);break}case u.ARGUMENT:{var n;let i,o,s=(n=this.getDirective())!==null&&n!==void 0?n: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(z(o)?o:void 0);break}case u.LIST:{let i=tt(this.getInputType()),o=w(i)?i.ofType:i;this._defaultValueStack.push(void 0),this._inputTypeStack.push(z(o)?o:void 0);break}case u.OBJECT_FIELD:{let i=H(this.getInputType()),o,s;x(i)&&(s=i.getFields()[t.name.value],s&&(o=s.type)),this._defaultValueStack.push(s?s.defaultValue:void 0),this._inputTypeStack.push(z(o)?o:void 0);break}case u.ENUM:{let i=H(this.getInputType()),o;V(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 gs(e,t,r){let n=r.name.value;if(n===ke.name&&e.getQueryType()===t)return ke;if(n===Me.name&&e.getQueryType()===t)return Me;if(n===Pe.name&&ce(t))return Pe;if(S(t)||_(t))return t.getFields()[n]}function sr(e,t){return{enter(...r){let n=r[0];e.enter(n);let i=We(t,n.kind).enter;if(i){let o=i.apply(t,r);return o!==void 0&&(e.leave(n),mt(o)&&e.enter(o)),o}},leave(...r){let n=r[0],i=We(t,n.kind).leave,o;return i&&(o=i.apply(t,r)),e.leave(n),o}}}function sn(e){return e.kind===u.OPERATION_DEFINITION||e.kind===u.FRAGMENT_DEFINITION}function an(e){return e.kind===u.SCHEMA_DEFINITION||we(e)||e.kind===u.DIRECTIVE_DEFINITION}function we(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 cn(e){return e.kind===u.SCHEMA_EXTENSION||ar(e)}function ar(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 un(e){return{Document(t){for(let r of t.definitions)if(!sn(r)){let n=r.kind===u.SCHEMA_DEFINITION||r.kind===u.SCHEMA_EXTENSION?"schema":'"'+r.name.value+'"';e.reportError(new f(`The ${n} definition is not executable.`,{nodes:r}))}return!1}}}function pn(e){return{Field(t){let r=e.getParentType();if(r&&!e.getFieldDef()){let i=e.getSchema(),o=t.name.value,s=Z("to use an inline fragment on",Es(i,r,o));s===""&&(s=Z(vs(r,o))),e.reportError(new f(`Cannot query field "${o}" on type "${r.name}".`+s,{nodes:t}))}}}}function Es(e,t,r){if(!ie(t))return[];let n=new Set,i=Object.create(null);for(let s of e.getPossibleTypes(t))if(s.getFields()[r]){n.add(s),i[s.name]=1;for(let a of s.getInterfaces()){var o;a.getFields()[r]&&(n.add(a),i[a.name]=((o=i[a.name])!==null&&o!==void 0?o:0)+1)}}return[...n].sort((s,a)=>{let c=i[a.name]-i[s.name];return c!==0?c:_(s)&&e.isSubType(s,a)?-1:_(a)&&e.isSubType(a,s)?1:Xe(s.name,a.name)}).map(s=>s.name)}function vs(e,t){if(S(e)||_(e)){let r=Object.keys(e.getFields());return re(t,r)}return[]}function ln(e){return{InlineFragment(t){let r=t.typeCondition;if(r){let n=P(e.getSchema(),r);if(n&&!ce(n)){let i=L(r);e.reportError(new f(`Fragment cannot condition on non composite type "${i}".`,{nodes:r}))}}},FragmentDefinition(t){let r=P(e.getSchema(),t.typeCondition);if(r&&!ce(r)){let n=L(t.typeCondition);e.reportError(new f(`Fragment "${t.name.value}" cannot condition on non composite type "${n}".`,{nodes:t.typeCondition}))}}}}function fn(e){return{...dn(e),Argument(t){let r=e.getArgument(),n=e.getFieldDef(),i=e.getParentType();if(!r&&n&&i){let o=t.name.value,s=n.args.map(c=>c.name),a=re(o,s);e.reportError(new f(`Unknown argument "${o}" on field "${i.name}.${n.name}".`+Z(a),{nodes:t}))}}}}function dn(e){let t=Object.create(null),r=e.getSchema(),n=r?r.getDirectives():ve;for(let s of n)t[s.name]=s.args.map(a=>a.name);let i=e.getDocument().definitions;for(let s of i)if(s.kind===u.DIRECTIVE_DEFINITION){var o;let a=(o=s.arguments)!==null&&o!==void 0?o:[];t[s.name.value]=a.map(c=>c.name.value)}return{Directive(s){let a=s.name.value,c=t[a];if(s.arguments&&c)for(let p of s.arguments){let l=p.name.value;if(!c.includes(l)){let d=re(l,c);e.reportError(new f(`Unknown argument "${l}" on directive "@${a}".`+Z(d),{nodes:p}))}}return!1}}}function cr(e){let t=Object.create(null),r=e.getSchema(),n=r?r.getDirectives():ve;for(let o of n)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=Ns(p);h&&!d.includes(h)&&e.reportError(new f(`Directive "@${l}" may not be used on ${h}.`,{nodes:o}))}}}function Ns(e){let t=e[e.length-1];switch("kind"in t||k(!1),t.kind){case u.OPERATION_DEFINITION:return Is(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 r=e[e.length-3];return"kind"in r||k(!1),r.kind===u.INPUT_OBJECT_TYPE_DEFINITION?I.INPUT_FIELD_DEFINITION:I.ARGUMENT_DEFINITION}default:k(!1,"Unexpected kind: "+y(t.kind))}}function Is(e){switch(e){case C.QUERY:return I.QUERY;case C.MUTATION:return I.MUTATION;case C.SUBSCRIPTION:return I.SUBSCRIPTION}}function mn(e){return{FragmentSpread(t){let r=t.name.value;e.getFragment(r)||e.reportError(new f(`Unknown fragment "${r}".`,{nodes:t.name}))}}}function ur(e){let t=e.getSchema(),r=t?t.getTypeMap():Object.create(null),n=Object.create(null);for(let o of e.getDocument().definitions)we(o)&&(n[o.name.value]=!0);let i=[...Object.keys(r),...Object.keys(n)];return{NamedType(o,s,a,c,p){let l=o.name.value;if(!r[l]&&!n[l]){var d;let h=(d=p[2])!==null&&d!==void 0?d:a,T=h!=null&&Rs(h);if(T&&Qi.includes(l))return;let g=re(l,T?Qi.concat(i):i);e.reportError(new f(`Unknown type "${l}".`+Z(g),{nodes:o}))}}}}var Qi=[...er,...ir].map(e=>e.name);function Rs(e){return"kind"in e&&(an(e)||cn(e))}function hn(e){let t=0;return{Document(r){t=r.definitions.filter(n=>n.kind===u.OPERATION_DEFINITION).length},OperationDefinition(r){!r.name&&t>1&&e.reportError(new f("This anonymous operation must be the only defined operation.",{nodes:r}))}}}function yn(e){var t,r,n;let i=e.getSchema(),o=(t=(r=(n=i?.astNode)!==null&&n!==void 0?n:i?.getQueryType())!==null&&r!==void 0?r: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 bs=3;function Tn(e){function t(r,n=Object.create(null),i=0){if(r.kind===u.FRAGMENT_SPREAD){let o=r.name.value;if(n[o]===!0)return!1;let s=e.getFragment(o);if(!s)return!1;try{return n[o]=!0,t(s,n,i)}finally{n[o]=void 0}}if(r.kind===u.FIELD&&(r.name.value==="fields"||r.name.value==="interfaces"||r.name.value==="possibleTypes"||r.name.value==="inputFields")&&(i++,i>=bs))return!0;if("selectionSet"in r&&r.selectionSet){for(let o of r.selectionSet.selections)if(t(o,n,i))return!0}return!1}return{Field(r){if((r.name.value==="__schema"||r.name.value==="__type")&&t(r))return e.reportError(new f("Maximum introspection depth exceeded",{nodes:[r]})),!1}}}function gn(e){let t=Object.create(null),r=[],n=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){n[s]=r.length;for(let c of a){let p=c.name.value,l=n[p];if(r.push(c),l===void 0){let d=e.getFragment(p);d&&i(d)}else{let d=r.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}))}r.pop()}n[s]=void 0}}}function En(e){let t=Object.create(null);return{OperationDefinition:{enter(){t=Object.create(null)},leave(r){let n=e.getRecursiveVariableUsages(r);for(let{node:i}of n){let o=i.name.value;t[o]!==!0&&e.reportError(new f(r.name?`Variable "$${o}" is not defined by operation "${r.name.value}".`:`Variable "$${o}" is not defined.`,{nodes:[i,r]}))}}},VariableDefinition(r){t[r.variable.name.value]=!0}}}function vn(e){let t=[],r=[];return{OperationDefinition(n){return t.push(n),!1},FragmentDefinition(n){return r.push(n),!1},Document:{leave(){let n=Object.create(null);for(let i of t)for(let o of e.getRecursivelyReferencedFragments(i))n[o.name.value]=!0;for(let i of r){let o=i.name.value;n[o]!==!0&&e.reportError(new f(`Fragment "${o}" is never used.`,{nodes:i}))}}}}}function Nn(e){let t=[];return{OperationDefinition:{enter(){t=[]},leave(r){let n=Object.create(null),i=e.getRecursiveVariableUsages(r);for(let{node:o}of i)n[o.name.value]=!0;for(let o of t){let s=o.variable.name.value;n[s]!==!0&&e.reportError(new f(r.name?`Variable "$${s}" is never used in operation "${r.name.value}".`:`Variable "$${s}" is never used.`,{nodes:o}))}}},VariableDefinition(r){t.push(r)}}}function pr(e){switch(e.kind){case u.OBJECT:return{...e,fields:Os(e.fields)};case u.LIST:return{...e,values:e.values.map(pr)};case u.INT:case u.FLOAT:case u.STRING:case u.BOOLEAN:case u.NULL:case u.ENUM:case u.VARIABLE:return e}}function Os(e){return e.map(t=>({...t,value:pr(t.value)})).sort((t,r)=>Xe(t.name.value,r.name.value))}function qi(e){return Array.isArray(e)?e.map(([t,r])=>`subfields "${t}" conflict because `+qi(r)).join(" and "):e}function On(e){let t=new mr,r=new bn,n=new Map;return{SelectionSet(i){let o=Ss(e,n,t,r,e.getParentType(),i);for(let[[s,a],c,p]of o){let l=qi(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 Ss(e,t,r,n,i,o){let s=[],[a,c]=dr(e,t,i,o);if(xs(e,s,t,r,n,a),c.length!==0)for(let p=0;p<c.length;p++){lr(e,s,t,r,n,!1,a,c[p]);for(let l=p+1;l<c.length;l++)fr(e,s,t,r,n,!1,c[p],c[l])}return s}function lr(e,t,r,n,i,o,s,a){if(n.has(s,a,o))return;n.add(s,a,o);let c=e.getFragment(a);if(!c)return;let[p,l]=Rn(e,r,c);if(s!==p){Sn(e,t,r,n,i,o,s,p);for(let d of l)lr(e,t,r,n,i,o,s,d)}}function fr(e,t,r,n,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]=Rn(e,r,c),[h,T]=Rn(e,r,p);Sn(e,t,r,n,i,o,l,h);for(let g of T)fr(e,t,r,n,i,o,s,g);for(let g of d)fr(e,t,r,n,i,o,g,a)}function _s(e,t,r,n,i,o,s,a,c){let p=[],[l,d]=dr(e,t,o,s),[h,T]=dr(e,t,a,c);Sn(e,p,t,r,n,i,l,h);for(let g of T)lr(e,p,t,r,n,i,l,g);for(let g of d)lr(e,p,t,r,n,i,h,g);for(let g of d)for(let A of T)fr(e,p,t,r,n,i,g,A);return p}function xs(e,t,r,n,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=Yi(e,r,n,i,!1,s,a[c],a[p]);l&&t.push(l)}}function Sn(e,t,r,n,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=Yi(e,r,n,i,o,c,d,h);T&&t.push(T)}}}function Yi(e,t,r,n,i,o,s,a){let[c,p,l]=s,[d,h,T]=a,g=i||c!==d&&S(c)&&S(d);if(!g){let se=p.name.value,he=h.name.value;if(se!==he)return[[o,`"${se}" and "${he}" are different fields`],[p],[h]];if(!Ls(p,h))return[[o,"they have differing arguments"],[p],[h]]}let A=l?.type,K=T?.type;if(A&&K&&In(A,K))return[[o,`they return conflicting types "${y(A)}" and "${y(K)}"`],[p],[h]];let Y=p.selectionSet,le=h.selectionSet;if(Y&&le){let se=_s(e,t,r,n,g,H(A),Y,H(K),le);return ws(se,o,p,h)}}function Ls(e,t){let r=e.arguments,n=t.arguments;if(r===void 0||r.length===0)return n===void 0||n.length===0;if(n===void 0||n.length===0||r.length!==n.length)return!1;let i=new Map(n.map(({name:o,value:s})=>[o.value,s]));return r.every(o=>{let s=o.value,a=i.get(o.name.value);return a===void 0?!1:Bi(s)===Bi(a)})}function Bi(e){return L(pr(e))}function In(e,t){return w(e)?w(t)?In(e.ofType,t.ofType):!0:w(t)?!0:R(e)?R(t)?In(e.ofType,t.ofType):!0:R(t)?!0:X(e)||X(t)?e!==t:!1}function dr(e,t,r,n){let i=t.get(n);if(i)return i;let o=Object.create(null),s=Object.create(null);Hi(e,r,n,o,s);let a=[o,Object.keys(s)];return t.set(n,a),a}function Rn(e,t,r){let n=t.get(r.selectionSet);if(n)return n;let i=P(e.getSchema(),r.typeCondition);return dr(e,t,i,r.selectionSet)}function Hi(e,t,r,n,i){for(let o of r.selections)switch(o.kind){case u.FIELD:{let s=o.name.value,a;(S(t)||_(t))&&(a=t.getFields()[s]);let c=o.alias?o.alias.value:s;n[c]||(n[c]=[]),n[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?P(e.getSchema(),s):t;Hi(e,a,o.selectionSet,n,i);break}}}function ws(e,t,r,n){if(e.length>0)return[[t,e.map(([i])=>i)],[r,...e.map(([,i])=>i).flat()],[n,...e.map(([,,i])=>i).flat()]]}var mr=class{constructor(){this._data=new Map}has(t,r,n){var i;let o=(i=this._data.get(t))===null||i===void 0?void 0:i.get(r);return o===void 0?!1:n?!0:n===o}add(t,r,n){let i=this._data.get(t);i===void 0?this._data.set(t,new Map([[r,n]])):i.set(r,n)}},bn=class{constructor(){this._orderedPairSet=new mr}has(t,r,n){return t<r?this._orderedPairSet.has(t,r,n):this._orderedPairSet.has(r,t,n)}add(t,r,n){t<r?this._orderedPairSet.add(t,r,n):this._orderedPairSet.add(r,t,n)}};function _n(e){return{InlineFragment(t){let r=e.getType(),n=e.getParentType();if(ce(r)&&ce(n)&&!Jr(e.getSchema(),r,n)){let i=y(n),o=y(r);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 r=t.name.value,n=Ds(e,r),i=e.getParentType();if(n&&i&&!Jr(e.getSchema(),n,i)){let o=y(i),s=y(n);e.reportError(new f(`Fragment "${r}" cannot be spread here as objects of type "${o}" can never be of type "${s}".`,{nodes:t}))}}}}function Ds(e,t){let r=e.getFragment(t);if(r){let n=P(e.getSchema(),r.typeCondition);if(ce(n))return n}}function xn(e){let t=e.getSchema(),r=Object.create(null);for(let i of e.getDocument().definitions)we(i)&&(r[i.name.value]=i);return{ScalarTypeExtension:n,ObjectTypeExtension:n,InterfaceTypeExtension:n,UnionTypeExtension:n,EnumTypeExtension:n,InputObjectTypeExtension:n};function n(i){let o=i.name.value,s=r[o],a=t?.getType(o),c;if(s?c=As[s.kind]:a&&(c=Fs(a)),c){if(c!==i.kind){let p=Cs(i.kind);e.reportError(new f(`Cannot extend non-${p} type "${o}".`,{nodes:s?[s,i]:i}))}}else{let p=Object.keys({...r,...t?.getTypeMap()}),l=re(o,p);e.reportError(new f(`Cannot extend type "${o}" because it is not defined.`+Z(l),{nodes:i.name}))}}}var As={[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 Fs(e){if(Ee(e))return u.SCALAR_TYPE_EXTENSION;if(S(e))return u.OBJECT_TYPE_EXTENSION;if(_(e))return u.INTERFACE_TYPE_EXTENSION;if(J(e))return u.UNION_TYPE_EXTENSION;if(V(e))return u.ENUM_TYPE_EXTENSION;if(x(e))return u.INPUT_OBJECT_TYPE_EXTENSION;k(!1,"Unexpected type: "+y(e))}function Cs(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:k(!1,"Unexpected kind: "+y(e))}}function Ln(e){return{...wn(e),Field:{leave(t){var r;let n=e.getFieldDef();if(!n)return!1;let i=new Set((r=t.arguments)===null||r===void 0?void 0:r.map(o=>o.name.value));for(let o of n.args)if(!i.has(o.name)&&Oe(o)){let s=y(o.type);e.reportError(new f(`Field "${n.name}" argument "${o.name}" of type "${s}" is required, but it was not provided.`,{nodes:t}))}}}}}function wn(e){var t;let r=Object.create(null),n=e.getSchema(),i=(t=n?.getDirectives())!==null&&t!==void 0?t:ve;for(let a of i)r[a.name]=ye(a.args.filter(Oe),c=>c.name);let o=e.getDocument().definitions;for(let a of o)if(a.kind===u.DIRECTIVE_DEFINITION){var s;let c=(s=a.arguments)!==null&&s!==void 0?s:[];r[a.name.value]=ye(c.filter(ks),p=>p.name.value)}return{Directive:{leave(a){let c=a.name.value,p=r[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 A=et(g.type)?y(g.type):L(g.type);e.reportError(new f(`Directive "@${c}" argument "${T}" of type "${A}" is required, but it was not provided.`,{nodes:a}))}}}}}}function ks(e){return e.type.kind===u.NON_NULL_TYPE&&e.defaultValue==null}function Dn(e){return{Field(t){let r=e.getType(),n=t.selectionSet;if(r)if(X(H(r))){if(n){let i=t.name.value,o=y(r);e.reportError(new f(`Field "${i}" must not have a selection since type "${o}" has no subfields.`,{nodes:n}))}}else if(n){if(n.selections.length===0){let i=t.name.value,o=y(r);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(r);e.reportError(new f(`Field "${i}" of type "${o}" must have a selection of subfields. Did you mean "${i} { ... }"?`,{nodes:t}))}}}}function hr(e){return e.map(t=>typeof t=="number"?"["+t.toString()+"]":"."+t).join("")}function Ve(e,t,r){return{prev:e,key:t,typename:r}}function ee(e){let t=[],r=e;for(;r;)t.push(r.key),r=r.prev;return t.reverse()}function Ji(e,t,r=Ms){return wt(e,t,r,void 0)}function Ms(e,t,r){let n="Invalid value "+y(t);throw e.length>0&&(n+=` at "value${hr(e)}"`),r.message=n+": "+r.message,r}function wt(e,t,r,n){if(R(t)){if(e!=null)return wt(e,t.ofType,r,n);r(ee(n),e,new f(`Expected non-nullable type "${y(t)}" not to be null.`));return}if(e==null)return null;if(w(t)){let i=t.ofType;return nt(e)?Array.from(e,(o,s)=>{let a=Ve(n,s,void 0);return wt(o,i,r,a)}):[wt(e,i,r,n)]}if(x(t)){if(!Q(e)||Array.isArray(e)){r(ee(n),e,new f(`Expected type "${t.name}" to be an object.`));return}let i=Object.create(null),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(R(s.type)){let c=y(s.type);r(ee(n),e,new f(`Field "${s.name}" of required type "${c}" was not provided.`))}continue}i[s.name]=wt(a,s.type,r,Ve(n,s.name,t.name))}for(let s of Object.keys(e))if(!o[s]){let a=re(s,Object.keys(t.getFields()));r(ee(n),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&&r(ee(n),e,new f(`Exactly one key must be specified for OneOf type "${t.name}".`));let a=s[0],c=i[a];c===null&&r(ee(n).concat(a),c,new f(`Field "${a}" must be non-null.`))}return{...i}}if(X(t)){let i;try{i=t.parseValue(e)}catch(o){o instanceof f?r(ee(n),e,o):r(ee(n),e,new f(`Expected type "${t.name}". `+o.message,{originalError:o}));return}return i===void 0&&r(ee(n),e,new f(`Expected type "${t.name}".`)),i}k(!1,"Unexpected input type: "+y(t))}function Ge(e,t,r){if(e){if(e.kind===u.VARIABLE){let n=e.name.value;if(r==null||r[n]===void 0)return;let i=r[n];return i===null&&R(t)?void 0:i}if(R(t))return e.kind===u.NULL?void 0:Ge(e,t.ofType,r);if(e.kind===u.NULL)return null;if(w(t)){let n=t.ofType;if(e.kind===u.LIST){let o=[];for(let s of e.values)if(zi(s,r)){if(R(n))return;o.push(null)}else{let a=Ge(s,n,r);if(a===void 0)return;o.push(a)}return o}let i=Ge(e,n,r);return i===void 0?void 0:[i]}if(x(t)){if(e.kind!==u.OBJECT)return;let n=Object.create(null),i=ye(e.fields,o=>o.name.value);for(let o of Object.values(t.getFields())){let s=i[o.name];if(!s||zi(s.value,r)){if(o.defaultValue!==void 0)n[o.name]=o.defaultValue;else if(R(o.type))return;continue}let a=Ge(s.value,o.type,r);if(a===void 0)return;n[o.name]=a}if(t.isOneOf){let o=Object.keys(n);if(o.length!==1||n[o[0]]===null)return}return n}if(X(t)){let n;try{n=t.parseLiteral(e,r)}catch{return}return n===void 0?void 0:n}k(!1,"Unexpected input type: "+y(t))}}function zi(e,t){return e.kind===u.VARIABLE&&(t==null||t[e.name.value]===void 0)}function An(e,t,r,n){let i=[],o=n?.maxErrors;try{let s=Ps(e,t,r,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 Ps(e,t,r,n){let i=Object.create(null);for(let o of t){let s=o.variable.name.value,a=P(e,o.type);if(!z(a)){let p=L(o.type);n(new f(`Variable "$${s}" expected value of type "${p}" which cannot be used as an input type.`,{nodes:o.type}));continue}if(!Xi(r,s)){if(o.defaultValue)i[s]=Ge(o.defaultValue,a);else if(R(a)){let p=y(a);n(new f(`Variable "$${s}" of required type "${p}" was not provided.`,{nodes:o}))}continue}let c=r[s];if(c===null&&R(a)){let p=y(a);n(new f(`Variable "$${s}" of non-null type "${p}" must not be null.`,{nodes:o}));continue}i[s]=Ji(c,a,(p,l,d)=>{let h=`Variable "$${s}" got invalid value `+y(l);p.length>0&&(h+=` at "${s}${hr(p)}"`),n(new f(h+"; "+d.message,{nodes:o,originalError:d}))})}return{...i}}function yr(e,t,r){var n;let i=Object.create(null),o=(n=t.arguments)!==null&&n!==void 0?n:[],s=ye(o,a=>a.name.value);for(let a of e.args){let c=a.name,p=a.type,l=s[c];if(!l){if(a.defaultValue!==void 0)i[c]=a.defaultValue;else if(R(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(r==null||!Xi(r,g)){if(a.defaultValue!==void 0)i[c]=a.defaultValue;else if(R(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=r[g]==null}if(h&&R(p))throw new f(`Argument "${c}" of non-null type "${y(p)}" must not be null.`,{nodes:d});let T=Ge(d,p,r);if(T===void 0)throw new f(`Argument "${c}" has invalid value ${L(d)}.`,{nodes:d});i[c]=T}return{...i}}function Tr(e,t,r){var n;let i=(n=t.directives)===null||n===void 0?void 0:n.find(o=>o.name.value===e.name);if(i)return yr(e,i,r)}function Xi(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function Er(e,t,r,n,i){let o=new Map;return gr(e,t,r,n,i,o,new Set),o}function Wi(e,t,r,n,i){let o=new Map,s=new Set;for(let a of i)a.selectionSet&&gr(e,t,r,n,a.selectionSet,o,s);return o}function gr(e,t,r,n,i,o,s){for(let a of i.selections)switch(a.kind){case u.FIELD:{if(!Fn(r,a))continue;let c=Us(a),p=o.get(c);p!==void 0?p.push(a):o.set(c,[a]);break}case u.INLINE_FRAGMENT:{if(!Fn(r,a)||!Ki(e,a,n))continue;gr(e,t,r,n,a.selectionSet,o,s);break}case u.FRAGMENT_SPREAD:{let c=a.name.value;if(s.has(c)||!Fn(r,a))continue;s.add(c);let p=t[c];if(!p||!Ki(e,p,n))continue;gr(e,t,r,n,p.selectionSet,o,s);break}}}function Fn(e,t){let r=Tr(rr,t,e);if(r?.if===!0)return!1;let n=Tr(tr,t,e);return n?.if!==!1}function Ki(e,t,r){let n=t.typeCondition;if(!n)return!0;let i=P(e,n);return i===r?!0:ie(i)?e.isSubType(i,r):!1}function Us(e){return e.alias?e.alias.value:e.name.value}function Cn(e){return{OperationDefinition(t){if(t.operation==="subscription"){let r=e.getSchema(),n=r.getSubscriptionType();if(n){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=Er(r,a,o,n,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 st(e,t){let r=new Map;for(let n of e){let i=t(n),o=r.get(i);o===void 0?r.set(i,[n]):o.push(n)}return r}function kn(e){return{DirectiveDefinition(n){var i;let o=(i=n.arguments)!==null&&i!==void 0?i:[];return r(`@${n.name.value}`,o)},InterfaceTypeDefinition:t,InterfaceTypeExtension:t,ObjectTypeDefinition:t,ObjectTypeExtension:t};function t(n){var i;let o=n.name.value,s=(i=n.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:[];r(`${o}.${p}`,l)}return!1}function r(n,i){let o=st(i,s=>s.name.value);for(let[s,a]of o)a.length>1&&e.reportError(new f(`Argument "${n}(${s}:)" can only be defined once.`,{nodes:a.map(c=>c.name)}));return!1}}function vr(e){return{Field:t,Directive:t};function t(r){var n;let i=(n=r.arguments)!==null&&n!==void 0?n:[],o=st(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 Mn(e){let t=Object.create(null),r=e.getSchema();return{DirectiveDefinition(n){let i=n.name.value;if(r!=null&&r.getDirective(i)){e.reportError(new f(`Directive "@${i}" already exists in the schema. It cannot be redefined.`,{nodes:n.name}));return}return t[i]?e.reportError(new f(`There can be only one directive named "@${i}".`,{nodes:[t[i],n.name]})):t[i]=n.name,!1}}}function Nr(e){let t=Object.create(null),r=e.getSchema(),n=r?r.getDirectives():ve;for(let a of n)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(we(a)||ar(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 Pn(e){let t=e.getSchema(),r=t?t.getTypeMap():Object.create(null),n=Object.create(null);return{EnumTypeDefinition:i,EnumTypeExtension:i};function i(o){var s;let a=o.name.value;n[a]||(n[a]=Object.create(null));let c=(s=o.values)!==null&&s!==void 0?s:[],p=n[a];for(let l of c){let d=l.name.value,h=r[a];V(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 Un(e){let t=e.getSchema(),r=t?t.getTypeMap():Object.create(null),n=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;n[a]||(n[a]=Object.create(null));let c=(s=o.fields)!==null&&s!==void 0?s:[],p=n[a];for(let l of c){let d=l.name.value;$s(r[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 $s(e,t){return S(e)||_(e)||x(e)?e.getFields()[t]!=null:!1}function $n(e){let t=Object.create(null);return{OperationDefinition:()=>!1,FragmentDefinition(r){let n=r.name.value;return t[n]?e.reportError(new f(`There can be only one fragment named "${n}".`,{nodes:[t[n],r.name]})):t[n]=r.name,!1}}}function Ir(e){let t=[],r=Object.create(null);return{ObjectValue:{enter(){t.push(r),r=Object.create(null)},leave(){let n=t.pop();n||k(!1),r=n}},ObjectField(n){let i=n.name.value;r[i]?e.reportError(new f(`There can be only one input field named "${i}".`,{nodes:[r[i],n.name]})):r[i]=n.name}}}function Vn(e){let t=Object.create(null);return{OperationDefinition(r){let n=r.name;return n&&(t[n.value]?e.reportError(new f(`There can be only one operation named "${n.value}".`,{nodes:[t[n.value],n]})):t[n.value]=n),!1},FragmentDefinition:()=>!1}}function Gn(e){let t=e.getSchema(),r=Object.create(null),n=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=r[p];n[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]})):r[p]=c}return!1}}function jn(e){let t=Object.create(null),r=e.getSchema();return{ScalarTypeDefinition:n,ObjectTypeDefinition:n,InterfaceTypeDefinition:n,UnionTypeDefinition:n,EnumTypeDefinition:n,InputObjectTypeDefinition:n};function n(i){let o=i.name.value;if(r!=null&&r.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 Qn(e){return{OperationDefinition(t){var r;let n=(r=t.variableDefinitions)!==null&&r!==void 0?r:[],i=st(n,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 Bn(e){return{ListValue(t){let r=tt(e.getParentInputType());if(!w(r))return je(e,t),!1},ObjectValue(t){let r=H(e.getInputType());if(!x(r))return je(e,t),!1;let n=ye(t.fields,i=>i.name.value);for(let i of Object.values(r.getFields()))if(!n[i.name]&&rt(i)){let s=y(i.type);e.reportError(new f(`Field "${r.name}.${i.name}" of required type "${s}" was not provided.`,{nodes:t}))}r.isOneOf&&Vs(e,t,r,n)},ObjectField(t){let r=H(e.getParentInputType());if(!e.getInputType()&&x(r)){let i=re(t.name.value,Object.keys(r.getFields()));e.reportError(new f(`Field "${t.name.value}" is not defined by type "${r.name}".`+Z(i),{nodes:t}))}},NullValue(t){let r=e.getInputType();R(r)&&e.reportError(new f(`Expected value of type "${y(r)}", found ${L(t)}.`,{nodes:t}))},EnumValue:t=>je(e,t),IntValue:t=>je(e,t),FloatValue:t=>je(e,t),StringValue:t=>je(e,t),BooleanValue:t=>je(e,t)}}function je(e,t){let r=e.getInputType();if(!r)return;let n=H(r);if(!X(n)){let i=y(r);e.reportError(new f(`Expected value of type "${i}", found ${L(t)}.`,{nodes:t}));return}try{if(n.parseLiteral(t,void 0)===void 0){let o=y(r);e.reportError(new f(`Expected value of type "${o}", found ${L(t)}.`,{nodes:t}))}}catch(i){let o=y(r);i instanceof f?e.reportError(i):e.reportError(new f(`Expected value of type "${o}", found ${L(t)}; `+i.message,{nodes:t,originalError:i}))}}function Vs(e,t,r,n){var i;let o=Object.keys(n);if(o.length!==1){e.reportError(new f(`OneOf Input Object "${r.name}" must specify exactly one key.`,{nodes:[t]}));return}let a=(i=n[o[0]])===null||i===void 0?void 0:i.value;(!a||a.kind===u.NULL)&&e.reportError(new f(`Field "${r.name}.${o[0]}" must be non-null.`,{nodes:[t]}))}function qn(e){return{VariableDefinition(t){let r=P(e.getSchema(),t.type);if(r!==void 0&&!z(r)){let n=t.variable.name.value,i=L(t.type);e.reportError(new f(`Variable "$${n}" cannot be non-input type "${i}".`,{nodes:t.type}))}}}}function Yn(e){let t=Object.create(null);return{OperationDefinition:{enter(){t=Object.create(null)},leave(r){let n=e.getRecursiveVariableUsages(r);for(let{node:i,type:o,defaultValue:s,parentType:a}of n){let c=i.name.value,p=t[c];if(p&&o){let l=e.getSchema(),d=P(l,p.type);if(d&&!Gs(l,d,p.defaultValue,o,s)){let h=y(d),T=y(o);e.reportError(new f(`Variable "$${c}" of type "${h}" used in position expecting type "${T}".`,{nodes:[p,i]}))}x(a)&&a.isOneOf&&Nt(d)&&e.reportError(new f(`Variable "$${c}" is of type "${d}" but must be non-nullable to be used for OneOf Input Object "${a}".`,{nodes:[p,i]}))}}}},VariableDefinition(r){t[r.variable.name.value]=r}}}function Gs(e,t,r,n,i){if(R(n)&&!R(t)){if(!(r!=null&&r.kind!==u.NULL)&&!(i!==void 0))return!1;let a=n.ofType;return Le(e,t,a)}return Le(e,t,n)}var Hn=Object.freeze([Tn]),at=Object.freeze([un,Vn,hn,Cn,ur,ln,qn,Dn,pn,$n,mn,vn,_n,gn,Qn,En,Nn,cr,Nr,fn,vr,Bn,Ln,Yn,On,Ir,...Hn]),js=Object.freeze([yn,Gn,jn,Pn,Un,kn,Mn,ur,cr,Nr,xn,dn,vr,Ir,wn]);var Jn=class{constructor(t,r){this._ast=t,this._fragments=void 0,this._fragmentSpreads=new Map,this._recursivelyReferencedFragments=new Map,this._onError=r}get[Symbol.toStringTag](){return"ASTValidationContext"}reportError(t){this._onError(t)}getDocument(){return this._ast}getFragment(t){let r;if(this._fragments)r=this._fragments;else{r=Object.create(null);for(let n of this.getDocument().definitions)n.kind===u.FRAGMENT_DEFINITION&&(r[n.name.value]=n);this._fragments=r}return r[t]}getFragmentSpreads(t){let r=this._fragmentSpreads.get(t);if(!r){r=[];let n=[t],i;for(;i=n.pop();)for(let o of i.selections)o.kind===u.FRAGMENT_SPREAD?r.push(o):o.selectionSet&&n.push(o.selectionSet);this._fragmentSpreads.set(t,r)}return r}getRecursivelyReferencedFragments(t){let r=this._recursivelyReferencedFragments.get(t);if(!r){r=[];let n=Object.create(null),i=[t.selectionSet],o;for(;o=i.pop();)for(let s of this.getFragmentSpreads(o)){let a=s.name.value;if(n[a]!==!0){n[a]=!0;let c=this.getFragment(a);c&&(r.push(c),i.push(c.selectionSet))}}this._recursivelyReferencedFragments.set(t,r)}return r}};var Dt=class extends Jn{constructor(t,r,n,i){super(r,i),this._schema=t,this._typeInfo=n,this._variableUsages=new Map,this._recursiveVariableUsages=new Map}get[Symbol.toStringTag](){return"ValidationContext"}getSchema(){return this._schema}getVariableUsages(t){let r=this._variableUsages.get(t);if(!r){let n=[],i=new ot(this._schema);Fe(t,sr(i,{VariableDefinition:()=>!1,Variable(o){n.push({node:o,type:i.getInputType(),defaultValue:i.getDefaultValue(),parentType:i.getParentInputType()})}})),r=n,this._variableUsages.set(t,r)}return r}getRecursiveVariableUsages(t){let r=this._recursiveVariableUsages.get(t);if(!r){r=this.getVariableUsages(t);for(let n of this.getRecursivelyReferencedFragments(t))r=r.concat(this.getVariableUsages(n));this._recursiveVariableUsages.set(t,r)}return r}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()}};var Qs=Ae(dt,e=>e.filter(t=>t!=="description"));function Rr(e,t,r=at,n,i=new ot(e)){var o;let s=(o=n?.maxErrors)!==null&&o!==void 0?o:100;t||O(!1,"Must provide document."),Lt(e);let a=Object.freeze({}),c=[],p=new Dt(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=Qr(r.map(d=>d(p)));try{Fe(t,sr(i,l),Qs)}catch(d){if(d!==a)throw d}return c}function Zi(e){let t;return function(n,i,o){t===void 0&&(t=new WeakMap);let s=t.get(n);s===void 0&&(s=new WeakMap,t.set(n,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(n,i,o),a.set(o,c)),c}}function zn(e){return Promise.all(Object.values(e)).then(t=>{let r=Object.create(null);for(let[n,i]of Object.keys(e).entries())r[i]=t[n];return r})}function eo(e,t,r){let n=r;for(let i of e)n=ae(n)?n.then(o=>t(o,i)):t(n,i);return n}function to(e){return e instanceof Error?e:new Xn(e)}var Xn=class extends Error{constructor(t){super("Unexpected error value: "+y(t)),this.name="NonErrorThrown",this.thrownValue=t}};function At(e,t,r){var n;let i=to(e);return Bs(i)?i:new f(i.message,{nodes:(n=i.nodes)!==null&&n!==void 0?n:t,source:i.source,positions:i.positions,path:r,originalError:i})}function Bs(e){return Array.isArray(e.path)}var qs=Zi((e,t,r)=>Wi(e.schema,e.fragments,e.variableValues,t,r)),Kn=class{constructor(){this._errorPositions=new Set,this._errors=[]}get errors(){return this._errors}add(t,r){this._hasNulledPosition(r)||(this._errorPositions.add(r),this._errors.push(t))}_hasNulledPosition(t){let r=t;for(;r!==void 0;){if(this._errorPositions.has(r))return!0;r=r.prev}return this._errorPositions.has(void 0)}};function xr(e){arguments.length<2||O(!1,"graphql@16 dropped long-deprecated support for positional arguments, please pass an object instead.");let{schema:t,document:r,variableValues:n,rootValue:i}=e;Ys(t,r,n);let o=Hs(e);if(!("schema"in o))return{errors:o};try{let{operation:s}=o,a=Js(o,s,i);return ae(a)?a.then(c=>br(c,o.collectedErrors.errors),c=>(o.collectedErrors.add(c,void 0),br(null,o.collectedErrors.errors))):br(a,o.collectedErrors.errors)}catch(s){return o.collectedErrors.add(s,void 0),br(null,o.collectedErrors.errors)}}function br(e,t){return t.length===0?{data:e}:{errors:t,data:e}}function Ys(e,t,r){t||O(!1,"Must provide document."),Lt(e),r==null||Q(r)||O(!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 Hs(e){var t,r,n;let{schema:i,document:o,rootValue:s,contextValue:a,variableValues:c,operationName:p,fieldResolver:l,typeResolver:d,subscribeFieldResolver:h,options:T}=e,g,A=Object.create(null);for(let le of o.definitions)switch(le.kind){case u.OPERATION_DEFINITION:if(p==null){if(g!==void 0)return[new f("Must provide operation name if query contains multiple operations.")];g=le}else((t=le.name)===null||t===void 0?void 0:t.value)===p&&(g=le);break;case u.FRAGMENT_DEFINITION:A[le.name.value]=le;break;default:}if(!g)return p!=null?[new f(`Unknown operation named "${p}".`)]:[new f("Must provide an operation.")];let K=(r=g.variableDefinitions)!==null&&r!==void 0?r:[],Y=An(i,K,c??{},{maxErrors:(n=T?.maxCoercionErrors)!==null&&n!==void 0?n:50});return Y.errors?Y.errors:{schema:i,fragments:A,rootValue:s,contextValue:a,operation:g,variableValues:Y.coerced,fieldResolver:l??_r,typeResolver:d??Zn,subscribeFieldResolver:h??_r,collectedErrors:new Kn}}function Js(e,t,r){let n=e.schema.getRootType(t.operation);if(n==null)throw new f(`Schema is not configured to execute ${t.operation} operation.`,{nodes:t});let i=Er(e.schema,e.fragments,e.variableValues,n,t.selectionSet),o=void 0;switch(t.operation){case C.QUERY:return Or(e,n,r,o,i);case C.MUTATION:return zs(e,n,r,o,i);case C.SUBSCRIPTION:return Or(e,n,r,o,i)}}function zs(e,t,r,n,i){return eo(i.entries(),(o,[s,a])=>{let c=Ve(n,s,t.name),p=io(e,t,r,a,c);return p===void 0?o:ae(p)?p.then(l=>(o[s]=l,o)):(o[s]=p,o)},Object.create(null))}function Or(e,t,r,n,i){let o=Object.create(null),s=!1;try{for(let[a,c]of i.entries()){let p=Ve(n,a,t.name),l=io(e,t,r,c,p);l!==void 0&&(o[a]=l,ae(l)&&(s=!0))}}catch(a){if(s)return zn(o).finally(()=>{throw a});throw a}return s?zn(o):o}function io(e,t,r,n,i){var o;let s=ea(e.schema,t,n[0]);if(!s)return;let a=s.type,c=(o=s.resolve)!==null&&o!==void 0?o:e.fieldResolver,p=Xs(e,s,n,t,i);try{let l=yr(s,n[0],e.variableValues),d=e.contextValue,h=c(r,l,d,p),T;return ae(h)?T=h.then(g=>Ft(e,a,n,p,i,g)):T=Ft(e,a,n,p,i,h),ae(T)?T.then(void 0,g=>{let A=At(g,n,ee(i));return Sr(A,a,i,e)}):T}catch(l){let d=At(l,n,ee(i));return Sr(d,a,i,e)}}function Xs(e,t,r,n,i){return{fieldName:t.name,fieldNodes:r,returnType:t.type,parentType:n,path:i,schema:e.schema,fragments:e.fragments,rootValue:e.rootValue,operation:e.operation,variableValues:e.variableValues}}function Sr(e,t,r,n){if(R(t))throw e;return n.collectedErrors.add(e,r),null}function Ft(e,t,r,n,i,o){if(o instanceof Error)throw o;if(R(t)){let s=Ft(e,t.ofType,r,n,i,o);if(s===null)throw new Error(`Cannot return null for non-nullable field ${n.parentType.name}.${n.fieldName}.`);return s}if(o==null)return null;if(w(t))return Ks(e,t,r,n,i,o);if(X(t))return Ws(t,o);if(ie(t))return Zs(e,t,r,n,i,o);if(S(t))return Wn(e,t,r,n,i,o);k(!1,"Cannot complete value of unexpected output type: "+y(t))}function Ks(e,t,r,n,i,o){if(!nt(o))throw new f(`Expected Iterable, but did not find one for field "${n.parentType.name}.${n.fieldName}".`);let s=t.ofType,a=!1,c=Array.from(o,(p,l)=>{let d=Ve(i,l,void 0);try{let h;return ae(p)?h=p.then(T=>Ft(e,s,r,n,d,T)):h=Ft(e,s,r,n,d,p),ae(h)?(a=!0,h.then(void 0,T=>{let g=At(T,r,ee(d));return Sr(g,s,d,e)})):h}catch(h){let T=At(h,r,ee(d));return Sr(T,s,d,e)}});return a?Promise.all(c):c}function Ws(e,t){let r=e.serialize(t);if(r==null)throw new Error(`Expected \`${y(e)}.serialize(${y(t)})\` to return non-nullable value, returned: ${y(r)}`);return r}function Zs(e,t,r,n,i,o){var s;let a=(s=t.resolveType)!==null&&s!==void 0?s:e.typeResolver,c=e.contextValue,p=a(o,c,n,t);return ae(p)?p.then(l=>Wn(e,ro(l,e,t,r,n,o),r,n,i,o)):Wn(e,ro(p,e,t,r,n,o),r,n,i,o)}function ro(e,t,r,n,i,o){if(e==null)throw new f(`Abstract type "${r.name}" must resolve to an Object type at runtime for field "${i.parentType.name}.${i.fieldName}". Either the "${r.name}" type should provide a "resolveType" function or each possible type should provide an "isTypeOf" function.`,n);if(S(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 "${r.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 "${r.name}" was resolved to a type "${e}" that does not exist inside the schema.`,{nodes:n});if(!S(s))throw new f(`Abstract type "${r.name}" was resolved to a non-object type "${e}".`,{nodes:n});if(!t.schema.isSubType(r,s))throw new f(`Runtime Object type "${s.name}" is not a possible type for "${r.name}".`,{nodes:n});return s}function Wn(e,t,r,n,i,o){let s=qs(e,t,r);if(t.isTypeOf){let a=t.isTypeOf(o,e.contextValue,n);if(ae(a))return a.then(c=>{if(!c)throw no(t,o,r);return Or(e,t,o,i,s)});if(!a)throw no(t,o,r)}return Or(e,t,o,i,s)}function no(e,t,r){return new f(`Expected value of type "${e.name}" but got: ${y(t)}.`,{nodes:r})}var Zn=function(e,t,r,n){if(Q(e)&&typeof e.__typename=="string")return e.__typename;let i=r.schema.getPossibleTypes(n),o=[];for(let s=0;s<i.length;s++){let a=i[s];if(a.isTypeOf){let c=a.isTypeOf(e,t,r);if(ae(c))o[s]=c;else if(c)return o.length&&Promise.allSettled(o).catch(()=>{}),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})},_r=function(e,t,r,n){if(Q(e)||typeof e=="function"){let i=e[n.fieldName];return typeof i=="function"?e[n.fieldName](t,r,n):i}};function ea(e,t,r){let n=r.name.value;return n===ke.name&&e.getQueryType()===t?ke:n===Me.name&&e.getQueryType()===t?Me:n===Pe.name?Pe:t.getFields()[n]}import{EMPTY as oo,OperationOutcomeError as j,Operator as ba,allOk as so,badRequest as _e,created as ao,deepClone as Ct,evalFhirPath as co,generateId as uo,globalSchema as Oa,matchesSearchRequest as Sa,multipleMatches as Lr,normalizeOperationOutcome as _a,notFound as kt,preconditionFailed as xa,stringify as La}from"@medplum/core";import{applyPatch as wa}from"rfc6902";var wr={READER:"reader",WRITER:"writer"},ei=class{async searchOne(t){return(await this.search({...t,count:1})).entry?.[0]?.resource}async searchResources(t){return(await this.search(t)).entry?.map(n=>n.resource)??[]}async conditionalCreate(t,r,n){if(r.resourceType!==t.resourceType)throw new j(_e("Search type must match resource type for conditional update"));return r.count=2,r.sortRules=void 0,this.withTransaction(async()=>{let i=await this.searchResources(r);if(i.length===1){let s=i[0];if(!n?.assignedId&&t.id&&t.id!==s.id)throw new j(_e("Resource ID did not match resolved ID",t.resourceType+".id"));return{resource:i[0],outcome:so}}else if(i.length>1)throw new j(Lr);return{resource:await this.createResource(t,n),outcome:ao}},{serializable:!0})}async conditionalUpdate(t,r,n){if(r.resourceType!==t.resourceType)throw new j(_e("Search type must match resource type for conditional update"));return r.count=2,r.sortRules=void 0,this.withTransaction(async()=>{let i=await this.searchResources(r);if(i.length===0){if(t.id&&!n?.assignedId)throw new j(_e("Cannot perform create as update with client-assigned ID",t.resourceType+".id"));return{resource:await this.createResource(t,n),outcome:ao}}else if(i.length>1)throw new j(Lr);let o=i[0];if(t.id&&t.id!==o.id)throw new j(_e("Resource ID did not match resolved ID",t.resourceType+".id"));return{resource:await this.updateResource({...t,id:o.id},n),outcome:so}},{serializable:!0})}async conditionalDelete(t){t.count=2,t.sortRules=void 0,await this.withTransaction(async()=>{let r=await this.searchResources(t);if(r.length>1)throw new j(Lr);if(!r.length)return;let n=r[0];await this.deleteResource(n.resourceType,n.id)},{serializable:!0})}async conditionalPatch(t,r){return t.count=2,t.sortRules=void 0,this.withTransaction(async()=>{let n=await this.searchResources(t);if(n.length>1)throw new j(Lr);if(!n.length)throw new j(kt);let i=n[0];return this.patchResource(i.resourceType,i.id,r)},{serializable:!0})}},po=class extends ei{constructor(){super();F(this,"resources");F(this,"history");F(this,"seeding");this.resources=new Map,this.history=new Map,this.seeding=!1}async withSeeding(r){if(this.seeding)return r();this.seeding=!0;let n=await r();return this.seeding=!1,n}clear(){this.resources.clear(),this.history.clear()}setMode(r){}async createResource(r,n,i=!1){let o=JSON.parse(La(r)),s={...o,id:o.id??this.generateId(),meta:o.meta??{}};this.seeding||(s.meta.versionId&&delete s.meta.versionId,s.meta.lastUpdated&&delete s.meta.lastUpdated),s.meta.versionId??=uo(),s.meta.lastUpdated??=new Date().toISOString();let{resourceType:a,id:c}=s,p=this.resources.get(a);if(p||(p=new Map,this.resources.set(a,p)),!i&&p.has(c))throw new j(_e("Assigned ID is already in use"));p.set(c,s);let l=this.history.get(a);l||(l=new Map,this.history.set(a,l));let d=l.get(c);return d||(d=[],l.set(c,d)),d.push(s),Ct(s)}generateId(){return uo()}updateResource(r,n){if(!r.id)throw new j(_e("Missing id"));if(n?.ifMatch){let i=n.ifMatch,o=this.resources.get(r.resourceType)?.get(r.id);if(!o)throw new j(kt);if(o.meta?.versionId!==i)throw new j(xa)}return this.createResource(r,void 0,!0)}async patchResource(r,n,i){let o=await this.readResource(r,n);try{let s=wa(o,i).filter(Boolean);if(s.length>0)throw new j(_e(s.map(a=>a.message).join(`
|
|
60
60
|
`)))}catch(s){throw new j(_a(s))}return o.meta&&(delete o.meta.versionId,delete o.meta.lastUpdated),this.updateResource(o)}async readResource(r,n){let i=this.resources.get(r)?.get(n);if(!i)throw new j(kt);return Ct(i)}async readReference(r){let n=r.reference?.split("/");if(n?.length!==2)throw new j(_e("Invalid reference"));return this.readResource(n[0],n[1])}async readReferences(r){return Promise.all(r.map(n=>this.readReference(n)))}async readHistory(r,n){await this.readResource(r,n);let i=(this.history.get(r)?.get(n)??[]).reverse().map(o=>({resource:Ct(o)}));return{resourceType:"Bundle",type:"history",...i.length?{entry:i}:void 0}}async readVersion(r,n,i){await this.readResource(r,n);let o=this.history.get(r)?.get(n)?.find(s=>s.meta?.versionId===i);if(!o)throw new j(kt);return Ct(o)}async search(r){let{resourceType:n}=r,i=this.resources.get(n)??new Map,o=[];for(let a of i.values())Sa(a,r)&&o.push(a);let s=o.map(a=>({resource:Ct(a)}));for(let a of r.sortRules??oo)s=s.sort((c,p)=>Da(c.resource,p.resource,a));return r.offset!==void 0&&(s=s.slice(r.offset)),r.count!==void 0&&(s=s.slice(0,r.count)),{resourceType:"Bundle",type:"searchset",entry:s.length?s:void 0,total:o.length}}async searchByReference(r,n,i){r.filters??=[];let o={};for(let s of i){r.filters.push({code:n,operator:ba.EQUALS,value:s});let a=await this.search(r);o[s]=[];for(let c of a.entry??oo)c.resource&&o[s].push(c.resource);r.filters.pop()}return o}async deleteResource(r,n){if(!this.resources.get(r)?.get(n))throw new j(kt);this.resources.get(r)?.delete(n)}withTransaction(r){return r(void 0)}},Da=(e,t,r)=>{let i=Oa.types[e.resourceType]?.searchParams?.[r.code]?.expression;if(!i)return 0;let o=JSON.stringify(co(i,e)),s=JSON.stringify(co(i,t));return o.localeCompare(s)*(r.descending?-1:1)};import{capitalize as ja,getDataType as To,isResourceType as Qa}from"@medplum/core";import{DEFAULT_MAX_SEARCH_COUNT as Aa,DEFAULT_SEARCH_COUNT as Fa,getReferenceString as Ca,getSearchParameters as ka,Operator as Ma,parseSearchRequest as Pa}from"@medplum/core";import Ua from"dataloader";var Dr={base64Binary:v,boolean:G,canonical:v,code:v,date:v,dateTime:v,decimal:pe,id:fe,instant:v,integer:pe,markdown:v,number:pe,oid:v,positiveInt:pe,string:v,time:v,unsignedInt:pe,uri:v,url:v,uuid:v,xhtml:v,"http://hl7.org/fhirpath/System.Boolean":G,"http://hl7.org/fhirpath/System.Date":v,"http://hl7.org/fhirpath/System.DateTime":v,"http://hl7.org/fhirpath/System.Decimal":pe,"http://hl7.org/fhirpath/System.Integer":pe,"http://hl7.org/fhirpath/System.String":v,"http://hl7.org/fhirpath/System.Time":v};function lo(e,t,r){let n;if(t){let o=r._reference;delete r._reference,n={code:o,operator:Ma.EQUALS,value:Ca(t)}}return r=Object.fromEntries(Object.entries(r).map(([o,s])=>[$a(o),s])),{searchRequest:Pa(e,r),referenceFilter:n}}function fo(e,t){let r=e.filters||[];e.filters=[t,...r]}function mo(e,t,r){let{searchRequest:n,referenceFilter:i}=lo(e,t,r);return i&&fo(n,i),n}function ti(e,t){e.count=Math.min(e.count??Fa,t??Aa)}function $a(e){return e.startsWith("_")?e:e.replaceAll("_","-")}function ri(e){return e.replaceAll("-","_")}function Va(e){return JSON.stringify(e,(r,n)=>n&&typeof n=="object"&&!Array.isArray(n)?Object.keys(n).sort((i,o)=>i.localeCompare(o)).reduce((i,o)=>(i[o]=n[o],i),{}):n)}async function Ar(e,t,r,n){if(r.searchCount++,r.config?.graphqlMaxSearches&&r.searchCount>r.config.graphqlMaxSearches)throw new Error("Maximum number of searches exceeded");let i=n.fieldName,o=i.substring(0,i.length-4),{searchRequest:s,referenceFilter:a}=lo(o,e,t);ti(s,r.config?.graphqlMaxSearches);let c=r.config?.graphqlBatchedSearchSize??0;if(c===0||!a)return a&&fo(s,a),(await r.repo.search(s)).entry?.map(h=>h.resource);let p=Va(s);return(r.searchDataLoaders[p]??=Ga(r.repo,s,c)).load(a)}function Ga(e,t,r){return new Ua(async n=>{let i=await e.searchByReference(t,n[0].code,n.map(o=>o.value));return n.map(o=>i[o.value])},{maxBatchSize:r})}function Mt(e){let t={_count:{type:ue,description:"Specify how many elements to return from a repeating list."},_offset:{type:ue,description:"Specify the offset to start at for a repeating element."},_sort:{type:v,description:"Specify the sort order by comma-separated list of sort rules in priority order."},_id:{type:v,description:"Select resources based on the logical id of the resource."},_lastUpdated:{type:v,description:"Select resources based on the last time they were changed."},_filter:{type:v,description:" The _filter parameter provides a syntax for expressing a set of query expressions on the underlying resources."},_cursor:{type:v,description:"The _cursor parameter is used to retrieve the next page of results from a previous search."}},r=ka(e);if(r)for(let[n,i]of Object.entries(r))t[ri(n)]={type:v,description:i.description};return t}function ni(e,t){return e.fieldNodes.some(r=>r.selectionSet?.selections.some(n=>n.kind===u.FIELD&&n.name.value===t))}function ho(e){return{resourceType:"OperationOutcome",issue:e.map(t=>({severity:"error",code:"invalid",details:{text:t.message}}))}}var yo={...Dr},ii;function Pt(e,t){let r=yo[e];return r||(r=Ba(e,t),yo[e]=r),r}function Ba(e,t){let r=To(e);return new xe({name:e+t,description:r.description,fields:()=>qa(e,t)})}function qa(e,t){let r={};if(Qa(e)){let n={description:"The type of resource",type:v};r.resourceType=n}return Ya(e,r,t),r}function Ya(e,t,r){let n=To(e);for(let[i,o]of Object.entries(n.elements))for(let s of o.type)Ha(t,i,o,s,r)}function Ha(e,t,r,n,i){let o=n.code;if(o==="Resource")return;(o==="Element"||o==="BackboneElement")&&(o=r.type[0].code);let s={description:r.description,type:Pt(o,i)};r.max>1&&(s.type=new D(new N(Pt(o,i)))),r.min>0&&!t.endsWith("[x]")&&(s.type=new N(s.type));let a=t.split(".").pop().replace("[x]",ja(n.code));e[a]=s}function go(){return ii||(ii=new xe({name:"PatchOperationInput",description:"A JSON Patch operation as per RFC 6902",fields:{op:{type:new N(v),description:"The operation to perform"},path:{type:new N(v),description:"A JSON-Pointer"},value:{type:v,description:"The value to use within the operations. (May be any scalar, but GraphQL input types are limited.)"}}})),ii}import{capitalize as Eo,evalFhirPathTyped as Ja,getDataType as vo,getResourceTypes as No,getSearchParameters as za,isLowerCase as Xa,isReference as Ka,isResourceTypeSchema as Wa,normalizeOperationOutcome as Za,OperationOutcomeError as ec,toJsBoolean as tc,toTypedValue as rc,tryGetDataType as nc}from"@medplum/core";var ct={...Dr};function Qe(e){let t=ct[e];return t||(t=oi(e),ct[e]=t),t}function oi(e){if(e==="ResourceList")return new Ce({name:"ResourceList",types:()=>No().map(Qe).filter(r=>!!r),resolveType:dc});let t=vo(e);return new B({name:e,description:t.description,fields:()=>ic(e)})}function ic(e){let t={};return oc(e,t),uc(e,t),t}function oc(e,t){let r=vo(e);Wa(r)&&(t.resourceType={type:new N(v),description:"Resource Type"}),e==="Reference"&&(t.resource={description:"Reference",type:Qe("ResourceList"),resolve:fc});for(let[n,i]of Object.entries(r.elements))for(let o of i.type)sc(t,n,i,o)}function sc(e,t,r,n){let i=n.code;(i==="Element"||i==="BackboneElement")&&(i=r.type[0].code),i==="Resource"&&(i="ResourceList");let o={description:r.description,type:pc(r,i,t),resolve:lc};r.max>1&&(o.args=ac(i));let s=t.split(".").pop().replace("[x]",Eo(n.code));e[s]=o}function ac(e){let t={_count:{type:ue,description:"Specify how many elements to return from a repeating list."},_offset:{type:ue,description:"Specify the offset to start at for a repeating element."}};if(!Xa(e.charAt(0))){t.fhirpath={type:v,description:"A FHIRPath statement selecting which of the subnodes is to be included"};let r=nc(e);if(r?.elements)for(let[n,i]of Object.entries(r.elements))for(let o of i.type)cc(t,n,i,o)}return t}function cc(e,t,r,n){let i=n.code,o=t.replace("[x]",Eo(i));switch(i){case"canonical":case"code":case"id":case"oid":case"string":case"uri":case"url":case"uuid":case"http://hl7.org/fhirpath/System.String":e[o]={type:v,description:r.description};break}}function uc(e,t){for(let r of No()){let n=Qe(r),i=za(r),o={},s=0;if(i)for(let[a,c]of Object.entries(i))c.target?.includes(e)&&(o[ri(a)]={value:a},s++);if(s>0){let a=new Ie({name:e+"_"+r+"_reference",values:o}),c=Mt(r);c._reference={type:new N(a),description:`Specify which property to use for reverse lookup for ${r}`},t[r+"List"]={type:new D(n),args:c,resolve:Ar},t[r+"Connection"]={type:si(r,n),args:c,resolve:ai}}}}function pc(e,t,r){let n=Qe(t);return e.max>1&&(n=new D(new N(n))),e.min!==0&&!r.endsWith("[x]")&&(n=new N(n)),n}async function lc(e,t,r,n){let i=e?.[n.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=>tc(Ja(a,[rc(l)])))),o&&(p=p.slice(o)),s&&(p=p.slice(0,s)),p}async function fc(e,t,r){if(Ka(e))try{return await r.dataLoader.load(e)}catch(n){throw new ec(Za(n),{cause:n})}}function dc(e){let t=e?.resourceType;if(t)return Qe(t).name}var Nc=new gc,ci;async function bo(e,t,r,n){let{query:i,operationName:o,variables:s}=e.body;if(!i)return[ut("Must provide query.")];let a;try{a=qt(i)}catch{return[ut("GraphQL syntax error.")]}let c=bc(),p=[...at,kc(r,e.config?.graphqlMaxDepth),Pc(r)],l=Rr(c,a,p);if(l.length>0)return[ho(l)];let d=Ic(i);if(d&&!r.options?.introspectionEnabled)return[Tc];!n?.batch&&!Rc(i)&&t.setMode(wr.READER);let h=new vc(g=>t.readReferences(g)),T=d&&Nc.get(i);if(!T){let g={repo:t,config:e.config,dataLoader:h,searchCount:0,searchDataLoaders:Object.create(null)};T=await xr({schema:c,document:a,contextValue:g,operationName:o,variableValues:s})}return[mc,T,{contentType:hc.JSON}]}function Ic(e){return e.includes("query IntrospectionQuery")||e.includes("__schema")}function Rc(e){return e.includes("mutation")}function bc(){return ci||(ci=Oc()),ci}function Oc(){for(let r of Io())ct[r]=oi(r);let e={},t={};for(let r of Io()){let n=Qe(r);e[r]={type:n,args:{id:{type:new N(fe),description:r+" ID"}},resolve:Lc},e[r+"List"]={type:new D(n),args:Mt(r),resolve:Ar},e[r+"Connection"]={type:si(r,n),args:Mt(r),resolve:ai},t[r+"Create"]={type:n,args:Sc(r),resolve:wc},t[r+"Update"]={type:n,args:_c(r),resolve:Dc},t[r+"Patch"]={type:n,args:Gc(r),resolve:Fc},t[r+"Delete"]={type:n,args:{id:{type:new N(fe),description:r+" ID"}},resolve:Ac}}return new Ue({query:new B({name:"QueryType",fields:e}),mutation:new B({name:"MutationType",fields:t})})}function Sc(e){return{res:{type:new N(Pt(e,"Create")),description:e+" Create"}}}function _c(e){return{id:{type:new N(fe),description:e+" ID"},res:{type:new N(Pt(e,"Update")),description:e+" Update"}}}function si(e,t){let r=e+"Connection",n=ct[r];return n||(n=xc(e,t),ct[r]=n),n}function xc(e,t){return new B({name:e+"Connection",fields:{count:{type:ue},offset:{type:ue},pageSize:{type:ue},first:{type:v},previous:{type:v},next:{type:v},last:{type:v},edges:{type:new D(new B({name:e+"ConnectionEdge",fields:{mode:{type:v},score:{type:pe},resource:{type:t}}}))}}})}async function ai(e,t,r,n){let i=n.fieldName,o=i.substring(0,i.length-10),s=mo(o,e,t);ni(n,"count")&&(s.total="accurate"),ni(n,"edges")||(s.count=0),ti(s,r.config?.graphqlMaxSearches);let a=await r.repo.search(s);return{count:a.total,offset:s.offset??0,pageSize:s.count??yc,edges:a.entry?.map(c=>({mode:c.search?.mode,score:c.search?.score,resource:c.resource})),next:Vc(a)}}async function Lc(e,t,r,n){try{return await r.dataLoader.load({reference:`${n.fieldName}/${t.id}`})}catch(i){throw new Ut(Ec(i),{cause:i})}}async function wc(e,t,r,n){let i=n.fieldName,o=i.substring(0,i.length-6),s=t.res;if(s.resourceType!==o)throw new Ut(ut("Invalid resourceType"));return r.repo.createResource(Ro(s))}async function Dc(e,t,r,n){let i=n.fieldName,o=i.substring(0,i.length-6),s=t.res,a=t.id;if(s.resourceType!==o)throw new Ut(ut("Invalid resourceType"));if(a!==s.id)throw new Ut(ut("Invalid ID"));return r.repo.updateResource(Ro(s))}async function Ac(e,t,r,n){let i=n.fieldName,o=i.substring(0,i.length-6);await r.repo.deleteResource(o,t.id)}async function Fc(e,t,r,n){let i=n.fieldName,o=i.substring(0,i.length-5),s=t.id,a=t.patch;if(!o||!s||!Array.isArray(a))throw new Ut(ut("Invalid patch arguments"));return r.repo.patchResource(o,s,a)}var Cc=12,kc=(e,t=Cc)=>r=>new ui(r,e,t),ui=class{constructor(t,r,n){F(this,"context");F(this,"maxDepth");F(this,"fragmentDepths");F(this,"router");this.context=t,this.router=r,this.fragmentDepths=Object.create(null),this.maxDepth=n}OperationDefinition(t){let r=this.getDepth(...t.selectionSet.selections);r.depth>this.maxDepth&&this.router.log("warn","Query max depth too high",{depth:r.depth,limit:this.maxDepth,query:t.loc?.source?.body})}getDepth(...t){let r={depth:-1};for(let n of t){let i={depth:0};if(n.kind===u.FIELD)n.selectionSet?.selections?(i=this.getDepth(...n.selectionSet.selections),i.depth+=1):i={depth:0,node:n};else if(n.kind===u.FRAGMENT_SPREAD){let o=n.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 n.kind===u.INLINE_FRAGMENT&&(i=this.getDepth(...n.selectionSet.selections));if(i.depth>this.maxDepth)return i;i.depth>r.depth&&(r=i)}return r}},Mc=1e4,Pc=(e,t)=>r=>new pi(r,e,t),pi=class{constructor(t,r,n){F(this,"context");F(this,"maxCost");F(this,"debug");F(this,"router");F(this,"fragmentCosts");this.context=t,this.maxCost=n?.maxCost??Mc,this.debug=n?.debug??!1,this.router=r,this.fragmentCosts=Object.create(null)}OperationDefinition(t){let r=0;for(let n of t.selectionSet.selections){let i=performance.now(),o=this.calculateCost(n);r+=o,this.log(n.kind,"node has final cost",o,"(",performance.now()-i,"ms)"),r>this.maxCost&&this.router.log("warn","GraphQL query too complex",{cost:r,limit:this.maxCost,query:t.loc?.source?.body})}}calculateCost(...t){let r=0;for(let n of t){if(n.kind===u.FIELD&&n.selectionSet){let i=0,o=1;Uc(n)?(this.log("Found search field",n.name.value),i=8,o=this.getCount(n.arguments)??20):$c(n)&&(this.log("Found linked resource"),i=1,o=2);let s=i+o*this.calculateCost(...n.selectionSet.selections);s&&this.log("Field",n.name.value,"costs",s),r+=s}else if(n.kind===u.FRAGMENT_SPREAD){let i=n.name.value,o=this.context.getFragment(i),s=this.fragmentCosts[i];if(s!==void 0)this.log("Fragment",i,"costs",s,"(cached)"),r+=s;else if(o){let a=this.calculateCost(...o.selectionSet.selections);this.fragmentCosts[i]=a,this.log("Fragment",i,"costs",a),r+=a}}else if(n.kind===u.INLINE_FRAGMENT){let i=this.calculateCost(...n.selectionSet.selections);this.log("Inline fragment on",n.typeCondition?.name.value,"costs",i),r+=i}if(r>this.maxCost)return r}return r}getCount(t){let r=t?.find(n=>n.name.value==="_count");if(r?.value.kind===u.INT)return Number.parseInt(r.value.value,10)}log(...t){this.debug&&console.log(...t)}};function Uc(e){return e.name.value.endsWith("List")}function $c(e){return e.name.value==="resource"}function Vc(e){let t=e.link?.find(r=>r.relation==="next")?.url;if(t)return new URL(t).searchParams.get("_cursor")||void 0}function Gc(e){return{id:{type:new N(fe),description:e+" ID"},patch:{type:new N(new D(new N(go()))),description:"Array of patch operations"}}}var Fr=class{constructor(){F(this,"routes",[])}add(t,r,n,i){let o=r.split("/").filter(s=>!!s).map(s=>s.startsWith(":")?{value:s.substring(1),param:!0}:{value:s});this.routes.push({method:t,path:o,handler:n,data:i})}find(t,r){let n=r.indexOf("?"),i=n>-1,o=r.substring(0,i?n:r.length).split("/").filter(Boolean),s,a=-1;for(let c of this.routes){let p=jc(c,t,o);p>a&&(s=c,a=p)}if(s)return{handler:s.handler,path:o.join("/"),params:Qc(s,o),query:i?Bc(r):void 0,data:s.data}}};function jc(e,t,r){if(t!==e.method||r.length!==e.path.length)return-1;let n=0;for(let i=0;i<r.length;i++)if(!e.path[i].param){if(r[i]!==e.path[i].value)return-1;n++}return n}function Qc(e,t){let r=Object.create(null);for(let n=0;n<t.length;n++)e.path[n].param&&(r[e.path[n].value]=t[n]);return r}function Bc(e){let t=new URL(e,"https://example.com/"),r=Object.create(null),n=t.searchParams;for(let i of n.keys()){let o=n.getAll(i);r[i]=o.length===1?o[0]:o}return r}async function Xc(e,t,r){let n=e.body;if(n.resourceType!=="Bundle")return[Re("Not a bundle")];let i=await Mr(e,t,r,n);return[me,i]}async function Kc(e,t,r,n){li(e,t,n);let{resourceType:i}=e.params,o=await t.search(Be(i,e.query));return[me,o]}async function Wc(e,t,r,n){li(e,t,n);let i=Be("MultipleTypes",e.query);if(!i.types||i.types.length===0)return[Re("No types specified")];let o=await t.search(i);return[me,o]}async function Zc(e,t,r,n){li(e,t,n);let{resourceType:i}=e.params,o=e.body,s=await t.search(Be(i,o));return[me,s]}function li(e,t,r){!r?.batch&&e.config?.searchOnReader&&t.setMode(wr.READER)}async function eu(e,t,r,n){let{resourceType:i}=e.params,o=e.body,s=!!n?.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=zc(e.headers["if-none-exist"]),c=await t.conditionalCreate(o,Be(`${i}?${a}`),{assignedId:s});return[c.outcome,c.resource]}return tu(i,o,t,{assignedId:s})}async function tu(e,t,r,n){if(e?.startsWith("$"))return[_o];if(t.resourceType!==e)return[Re(`Incorrect resource type: expected ${e}, but found ${t.resourceType||"<EMPTY>"}`)];let i=await r.createResource(t,n);return[Hc,i]}async function ru(e,t){let{resourceType:r,id:n}=e.params,i=await t.readResource(r,n);return[me,i]}async function nu(e,t){let{resourceType:r,id:n}=e.params,i=So(e.query,"_offset"),o=So(e.query,"_count"),s=await t.readHistory(r,n,{offset:i,limit:o});return[me,s]}async function iu(e,t){let{resourceType:r,id:n,vid:i}=e.params,o=await t.readVersion(r,n,i);return[me,o]}async function ou(e,t){let{resourceType:r,id:n}=e.params,i=e.body;return su(r,n,i,t,{ifMatch:fu(e.headers?.["if-match"])})}async function su(e,t,r,n,i){if(r.resourceType!==e)return[Re("Incorrect resource type")];if(r.id!==t)return[Re("Incorrect resource ID")];let o=await n.updateResource(r,i);return[me,o]}async function au(e,t,r,n){let{resourceType:i}=e.params,o=e.body,s=Be(i,e.query),a=await t.conditionalUpdate(o,s,{assignedId:n?.batch});return[a.outcome,a.resource]}async function cu(e,t){let{resourceType:r,id:n}=e.params;return await t.deleteResource(r,n),[me]}async function uu(e,t){let{resourceType:r}=e.params,n=Be(r,e.query);return await t.conditionalDelete(n),[me]}async function pu(e,t){let{resourceType:r,id:n}=e.params,i=e.body;if(!i)return[Re("Empty patch body")];if(!Array.isArray(i))return[Re("Patch body must be an array")];let o=await t.patchResource(r,n,i);return[me,o]}async function lu(e,t){let{resourceType:r}=e.params,n=e.body;if(!n)return[Re("Empty patch body")];if(!Array.isArray(n))return[Re("Patch body must be an array")];let i=Be(r,e.query),o=await t.conditionalPatch(i,n);return[me,o]}var Oo=class extends qc{constructor(r={}){super();F(this,"router",new Fr);F(this,"options");this.options=r,this.router.add("GET","",Wc,{interaction:"search-system"}),this.router.add("POST","",Xc,{interaction:"batch"}),this.router.add("GET",":resourceType",Kc,{interaction:"search-type"}),this.router.add("POST",":resourceType/_search",Zc,{interaction:"search-type"}),this.router.add("POST",":resourceType",eu,{interaction:"create"}),this.router.add("GET",":resourceType/:id",ru,{interaction:"read"}),this.router.add("GET",":resourceType/:id/_history",nu,{interaction:"history-instance"}),this.router.add("GET",":resourceType/:id/_history/:vid",iu,{interaction:"vread"}),this.router.add("PUT",":resourceType/:id",ou,{interaction:"update"}),this.router.add("PUT",":resourceType",au,{interaction:"update"}),this.router.add("DELETE",":resourceType/:id",cu,{interaction:"delete"}),this.router.add("DELETE",":resourceType",uu,{interaction:"delete"}),this.router.add("PATCH",":resourceType/:id",pu,{interaction:"patch"}),this.router.add("PATCH",":resourceType",lu,{interaction:"patch"}),this.router.add("POST","$graphql",bo,{interaction:"operation"})}add(r,n,i,o){this.router.add(r,n,i,{interaction:o??"operation"})}find(r,n){return this.router.find(r,n)}async handleRequest(r,n){let i=r.url;if(r.pathname)throw new Yc(Re("FhirRequest must specify url instead of pathname"));let o=this.find(r.method,i);if(!o)return[_o];let{handler:s,path:a,params:c,query:p}=o;r.params=c,r.pathname=a,p&&(r.query=p);try{return await s(r,n,this)}catch(l){return[Jc(l)]}}log(r,n,i){let o={type:r,message:n,data:i};this.dispatchEvent(o)}};function fu(e){if(!e)return;let t=/"([^"]+)"/.exec(e);return t?t[1]:void 0}function So(e,t){let r=e[t],n;return Array.isArray(r)?n=r.at(-1):n=r,n?Number.parseInt(n,10):void 0}function dg(e,t,r){return{method:e,url:t,pathname:"",query:{},params:{},body:r}}export{ei as FhirRepository,Oo as FhirRouter,po as MemoryRepository,wr as RepositoryMode,Fr as Router,tu as createResourceImpl,dg as makeSimpleRequest,Mr as processBatch,su as updateResourceImpl};
|
|
61
61
|
//# sourceMappingURL=index.mjs.map
|