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