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