@medplum/fhir-router 3.3.0 → 4.0.0

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