Liking cljdoc? Tell your friends :D
All platforms.

com.wsscode.pathom3.connect.runner


add-taken-path!clj/s

(add-taken-path! {:com.wsscode.pathom3.connect.runner/keys [node-run-stats*]}
                 {:com.wsscode.pathom3.connect.planner/keys [node-id]}
                 taken-path-id)
source

all-requires-ready?clj/s

(all-requires-ready? env {:com.wsscode.pathom3.connect.planner/keys [expects]})

Check if all requirements from the node are present in the current entity.

Check if all requirements from the node are present in the current entity.
sourceraw docstring

assoc-end-plan-statsclj/s

(assoc-end-plan-stats {:com.wsscode.pathom3.connect.planner/keys [graph]
                       :as env})
source

attribute-error-resolverclj/s

(attribute-error-resolver)
source

batch-group-input-groupsclj/s

(batch-group-input-groups batch-items)
source

batch-group-inputsclj/s

(batch-group-inputs batch-items)
source

batch-hold-tokenclj/s

(batch-hold-token env cache? op-name node cache-store input-data params)
source

cache-batch-itemclj/s

(cache-batch-item
  {env' :com.wsscode.pathom3.connect.runner/env
   :com.wsscode.pathom3.connect.runner/keys [node-resolver-input]
   :com.wsscode.pathom3.connect.operation/keys [cache? cache-store]
   :as batch-item}
  batch-op
  response)
source

cache-keyclj/s

(cache-key env input-data op-name params)
source

check-entity-requires!clj/s

(check-entity-requires! {:com.wsscode.pathom3.connect.planner/keys [graph]
                         :as env})

Verify if entity contains all required keys from graph index-ast. This is a shallow check (don't visit nested entities).

Verify if entity contains all required keys from graph index-ast. This is
a shallow check (don't visit nested entities).
sourceraw docstring

choose-cache-storeclj/s

(choose-cache-store env cache-store)
source

combine-inputs-with-responsesclj/s

(combine-inputs-with-responses input-groups inputs responses)

For batch we group the items with the same inputs so the resolver only needs to have each input once. This function is a helper to side the input batch items with the distinct list of responses.

For batch we group the items with the same inputs so the resolver only needs to have
each input once. This function is a helper to side the input batch items with the
distinct list of responses.
sourceraw docstring

default-choose-pathclj/s

(default-choose-path env or-node node-ids)
source

enhance-dynamic-inputclj/s

(enhance-dynamic-input {:com.wsscode.pathom3.connect.operation/keys
                          [dynamic-resolver?]}
                       node
                       input-data)
source

entity-missing-attribute-detailsclj/s

(entity-missing-attribute-details
  {:com.wsscode.pathom3.connect.planner/keys [graph] :as env}
  attr)
source

entry-astclj/s

(entry-ast graph k)

Get AST entry and pulls recursive query when needed.

Get AST entry and pulls recursive query when needed.
sourceraw docstring

fail-fastclj/s

(fail-fast {:com.wsscode.pathom3.error/keys [lenient-mode?]} error)
source

handle-or-errorclj/s

(handle-or-error env or-node res)
source

include-meta-statsclj/s

(include-meta-stats result
                    {:com.wsscode.pathom3.connect.runner/keys [omit-run-stats?]
                     :or {omit-run-stats? false}
                     :as env})
source

increase-error-indentclj/s

(increase-error-indent {:com.wsscode.pathom3.connect.runner/keys
                          [node-error-indent-level]
                        :or {node-error-indent-level 1}
                        :as env})
source

input-missing-checkclj/s

(input-missing-check env node entity input input+opts)

This will verify if all dependencies required by a resolver are satisfied.

One special case here might be a dependency from a batch process that's pending to run. In this case, we return a special block of data that tells Pathom to wait for the batch to run and try it again.

This will verify if all dependencies required by a resolver are satisfied.

One special case here might be a dependency from a batch process that's pending to run. In this case,
we return a special block of data that tells Pathom to wait for the batch to run and try it again.
sourceraw docstring

input-missing-detailclj/s

(input-missing-detail {:com.wsscode.pathom3.connect.planner/keys [graph]
                       :as env}
                      node
                      attr)
source

input-missing-detail-branch-nodeclj/s

(input-missing-detail-branch-node {:com.wsscode.pathom3.connect.planner/keys
                                     [graph]}
                                  branch-node
                                  attr)
source

input-missing-error-messageclj/s

(input-missing-error-message env node attr)
source

input-missing-error-message-leafclj/s

(input-missing-error-message-leaf nodes attr)
source

input-size-sortclj/s

(input-size-sort env or-node node-ids)

Find the nodes with highest input size and removes any node with sizes smaller than it.

Find the nodes with highest input size and removes any node with sizes smaller than it.
sourceraw docstring

invoke-batch-blockclj/s

(invoke-batch-block resolver batch-env batch-op input-groups inputs)
source

invoke-mutation!clj/s

(invoke-mutation! env {:keys [key] :as ast})

Run mutation from AST.

Run mutation from AST.
sourceraw docstring

invoke-not-found-mutation!clj/s

(invoke-not-found-mutation! env ast key)
source

invoke-resolver-from-nodeclj/s

(invoke-resolver-from-node env
                           {:com.wsscode.pathom3.connect.operation/keys
                              [op-name]
                            :com.wsscode.pathom3.connect.planner/keys [input]
                            :as node})

Evaluates a resolver using node information.

When this function runs the resolver, if filters the data to only include the keys mentioned by the resolver input. This is important to ensure that the resolver is not using some key that came accidentally due to execution order, that would lead to brittle executions.

Evaluates a resolver using node information.

When this function runs the resolver, if filters the data to only include the keys
mentioned by the resolver input. This is important to ensure that the resolver is
not using some key that came accidentally due to execution order, that would lead to
brittle executions.
sourceraw docstring

invoke-resolver-with-pluginsclj/s

(invoke-resolver-with-plugins resolver env input-data)
source

mark-batch-block-errorsclj/s

(mark-batch-block-errors err env batch-op input-groups inputs)
source

mark-batch-errorsclj/s

(mark-batch-errors error env batch-op batch-items)
source

mark-node-errorclj/s

(mark-node-error {:com.wsscode.pathom3.connect.runner/keys [node-run-stats*]
                  :as env}
                 {:com.wsscode.pathom3.connect.planner/keys [node-id]}
                 error)
source

mark-node-error-with-pluginsclj/s

(mark-node-error-with-plugins env node e)
source

merge-entity-dataclj/s

(merge-entity-data env entity new-data)

Specialized merge versions that work on entity data.

Specialized merge versions that work on entity data.
sourceraw docstring

merge-entity-to-root-dataclj/s

(merge-entity-to-root-data env env' _node)
source

merge-mutation-stats!clj/s

(merge-mutation-stats! {:com.wsscode.pathom3.connect.runner/keys
                          [node-run-stats*]}
                       {:com.wsscode.pathom3.connect.operation/keys [op-name]}
                       data)
source

merge-node-stats!clj/s

(merge-node-stats! {:com.wsscode.pathom3.connect.runner/keys [node-run-stats*]}
                   {:com.wsscode.pathom3.connect.planner/keys [node-id]}
                   data)
source

merge-resolver-response!clj/s

(merge-resolver-response! env response)

This function gets the map returned from the resolver and merge the data in the current cache-tree.

This function gets the map returned from the resolver and merge the data in the
current cache-tree.
sourceraw docstring

missing-maybe-in-pending-batch?clj/s

(missing-maybe-in-pending-batch? {:com.wsscode.pathom3.path/keys [path] :as env}
                                 input)

Check if there is any pending batching in the sub-path of the current input.

During the serial execution, a nested input process may be halted waiting to run after the all entities pass. In this case we need to also halt the execution to wait for that dependent input batch to run before moving on to process this node.

Check if there is any pending batching in the sub-path of the current input.

During the serial execution, a nested input process may be halted waiting to run
after the all entities pass. In this case we need to also halt the execution to wait
for that dependent input batch to run before moving on to process this node.
sourceraw docstring

node-error-indentclj/s

(node-error-indent {:com.wsscode.pathom3.connect.runner/keys
                      [node-error-indent-level]
                    :or {node-error-indent-level 1}})
source

node-failed-due-to-missing-inputs?clj/s

(node-failed-due-to-missing-inputs?
  {:com.wsscode.pathom3.connect.runner/keys [node-run-stats*]}
  {:com.wsscode.pathom3.connect.planner/keys [node-id]})

Checks via stats if a node had failed inputs, or if wasn't invoked at all (which also indicates lack of inputs).

Checks via stats if a node had failed inputs, or if wasn't invoked at all (which also indicates
lack of inputs).
sourceraw docstring

node-missing-input-error-detailsclj/s

(node-missing-input-error-details
  {:com.wsscode.pathom3.connect.runner/keys [node-run-stats*] :as env}
  {:com.wsscode.pathom3.connect.planner/keys [node-id input]
   :com.wsscode.pathom3.connect.operation/keys [op-name]
   :as node}
  attr)
source

node-weightclj/s

(node-weight {:com.wsscode.pathom3.connect.planner/keys [graph]
              :com.wsscode.pathom3.connect.runner/keys [resolver-weights*]
              :as env}
             node-id)

Sums up the weight of a node and its successors

Sums up the weight of a node and its successors
sourceraw docstring

normalize-ast-recursive-queryclj/s

(normalize-ast-recursive-query {:keys [query] :as ast} graph k)
source

or-error-exceptionclj/s

(or-error-exception or-node errors)
source

or-expected-optional?clj/s

(or-expected-optional? {:com.wsscode.pathom3.connect.planner/keys [graph]}
                       or-node)
source

pick-node-highestclj/s

(pick-node-highest {:com.wsscode.pathom3.connect.planner/keys [graph] :as env}
                   or-node
                   node-ids
                   criteria)

Starting from possible paths, find the nodes responsible for the attribute required by the OR node. Now compute the criteria from each node config it must result in a number. Keep only the nodes that have the highest criteria value.

Starting from possible paths, find the nodes responsible for the attribute required by the
OR node. Now compute the criteria from each node config it must result in a number. Keep only
the nodes that have the highest criteria value.
sourceraw docstring

placeholder-merge-entityclj/s

(placeholder-merge-entity env)

Create an entity to process the placeholder demands.

Create an entity to process the placeholder demands.
sourceraw docstring

placeholder-merge-entity*clj/s

(placeholder-merge-entity* {:com.wsscode.pathom3.connect.planner/keys [graph]
                            :com.wsscode.pathom3.connect.runner/keys
                              [source-entity]
                            :as env})

Create an entity to process the placeholder demands.

Create an entity to process the placeholder demands.
sourceraw docstring

plan-and-run!clj/s

(plan-and-run! env ast-or-graph entity-tree*)
source

priority-sortclj/s

(priority-sort env or-node node-ids)

Find the node path with the highest priority to run. Returns a set of the candidates with the same priority level.

Find the node path with the highest priority to run. Returns a set of the candidates
with the same priority level.
sourceraw docstring

process-attr-subqueryclj/s

(process-attr-subquery {:com.wsscode.pathom3.connect.planner/keys [graph]
                        :as env}
                       entity
                       k
                       v)
source

process-attr-subquery-astclj/s

(process-attr-subquery-ast graph k)
source

process-attr-subquery-keyclj/s

(process-attr-subquery-key k)
source

process-idents!clj/s

(process-idents! env idents)

Process the idents from the Graph, this will add the ident data into the child.

If there is ident data already, it gets merged with the ident value.

Process the idents from the Graph, this will add the ident data into the child.

If there is ident data already, it gets merged with the ident value.
sourceraw docstring

process-map-container-subqueryclj/s

(process-map-container-subquery env ast m)

Build a new map where the values are replaced with the map process of the subquery.

Build a new map where the values are replaced with the map process of the subquery.
sourceraw docstring

process-map-container?clj/s

(process-map-container? ast v)

Check if the map should be processed as a map-container, this means the sub-query should apply to the map values instead of the map itself.

This can be dictated by adding the ::pcr/map-container? meta data on the value, or requested by the query as part of the param.

Check if the map should be processed as a map-container, this means the sub-query
should apply to the map values instead of the map itself.

This can be dictated by adding the ::pcr/map-container? meta data on the value, or
requested by the query as part of the param.
sourceraw docstring

process-map-subqueryclj/s

(process-map-subquery env ast m)
source

process-map-subquery-dataclj/s

(process-map-subquery-data ast m)
source

process-mutations!clj/s

(process-mutations! {:com.wsscode.pathom3.connect.planner/keys [graph] :as env})

Runs the mutations gathered by the planner.

Runs the mutations gathered by the planner.
sourceraw docstring

process-sequence-subqueryclj/s

(process-sequence-subquery env ast s)
source

report-resolver-errorclj/s

(report-resolver-error {:com.wsscode.pathom3.path/keys [path]
                        :com.wsscode.pathom3.error/keys [lenient-mode?]
                        :as env}
                       {:com.wsscode.pathom3.connect.operation/keys [op-name]
                        :as node}
                       error)
source

report-resolver-io-statsclj/s

(report-resolver-io-stats {:com.wsscode.pathom3.connect.runner/keys
                             [omit-run-stats-resolver-io?]}
                          input-data
                          result)
source

resolver-already-ran?clj/s

(resolver-already-ran? {:com.wsscode.pathom3.connect.runner/keys
                          [node-run-stats*]}
                       {:com.wsscode.pathom3.connect.planner/keys [node-id]})
source

run-and-node!clj/s

(run-and-node! {:com.wsscode.pathom3.connect.planner/keys [graph] :as env}
               {:com.wsscode.pathom3.connect.planner/keys [run-and]
                :as and-node})

Given an AND node, runs every attached node, then runs the attached next.

Given an AND node, runs every attached node, then runs the attached next.
sourceraw docstring

run-batches!clj/s

(run-batches! env)
source

run-batches-pending!clj/s

(run-batches-pending! env)
source

run-batches-waiting!clj/s

(run-batches-waiting! env)
source

run-foreign-mutationclj/s

(run-foreign-mutation env {:keys [key] :as ast})
source

run-graph!clj/s

(run-graph! env ast-or-graph entity-tree*)

Plan and execute a request, given an environment (with indexes), the request AST and the entity-tree*.

Plan and execute a request, given an environment (with indexes), the request AST
and the entity-tree*.
sourceraw docstring

run-graph!*clj/s

(run-graph!* {:com.wsscode.pathom3.connect.planner/keys [graph] :as env})

Run the root node of the graph. As resolvers run, the result will be add to the entity cache tree.

Run the root node of the graph. As resolvers run, the result will be add to the
entity cache tree.
sourceraw docstring

run-graph-done!clj/s

(run-graph-done! env)
source

run-graph-entity-doneclj/s

(run-graph-entity-done env)
source

run-graph-impl!clj/s

(run-graph-impl! env ast-or-graph entity-tree*)
source

run-graph-with-pluginsclj/s

(run-graph-with-plugins env ast-or-graph entity-tree* impl!)
source

run-next-node!clj/s

(run-next-node! {:com.wsscode.pathom3.connect.planner/keys [graph] :as env}
                {:com.wsscode.pathom3.connect.planner/keys [run-next]})

Runs the next node associated with the node, in case it exists.

Runs the next node associated with the node, in case it exists.
sourceraw docstring

run-node!clj/s

(run-node! env node)

Run a node from the compute graph. This will start the processing on the sent node and them will run everything that's connected to this node as sequences of it.

The result is going to build up at ::p.ent/cache-tree*, after the run is concluded the output will be there.

Run a node from the compute graph. This will start the processing on the sent node
and them will run everything that's connected to this node as sequences of it.

The result is going to build up at ::p.ent/cache-tree*, after the run is concluded
the output will be there.
sourceraw docstring

run-or-node!clj/s

(run-or-node! {:com.wsscode.pathom3.connect.planner/keys [graph]
               :com.wsscode.pathom3.connect.runner/keys [choose-path]
               :or {choose-path default-choose-path}
               :as env}
              {:com.wsscode.pathom3.connect.planner/keys [run-or] :as or-node})
source

run-resolver-node!clj/s

(run-resolver-node! env node)

This function evaluates the resolver associated with the node.

First it checks if the expected results from the resolver are already available. In case they are, the resolver call is skipped.

This function evaluates the resolver associated with the node.

First it checks if the expected results from the resolver are already available. In
case they are, the resolver call is skipped.
sourceraw docstring

run-root-node!clj/s

(run-root-node! {:com.wsscode.pathom3.connect.planner/keys [graph] :as env})
source

runnable-graph?clj/s

(runnable-graph? graph)

Quick check to see if the graph has something to run. In the false case we can skip the running section.

Quick check to see if the graph has something to run. In the false case we can skip the
running section.
sourceraw docstring

setup-root-envclj/s

(setup-root-env env)
source

setup-runner-envclj/s

(setup-runner-env env entity-tree* cache-type)
source

sort-waiting-by-depthclj/s

(sort-waiting-by-depth waits)
source

special-resolver-signal?clj/s

(special-resolver-signal? response)
source

union-key-on-data?clj/s

(union-key-on-data? {:keys [union-key]} m)
source

user-demand-completed?clj/s

(user-demand-completed? env)
source

valid-resolver-response?clj/s

(valid-resolver-response? x)
source

validate-response!clj/s

(validate-response! env
                    {:com.wsscode.pathom3.connect.operation/keys [op-name]
                     :as node}
                    response)
source

wait-batch-responseclj/s

(wait-batch-response env node)
source

warn-batch-unsupportedclj/s

(warn-batch-unsupported env op-name)
source

weight-sortclj/s

(weight-sort {:com.wsscode.pathom3.connect.runner/keys [resolver-weights*]
              :as env}
             _or-node
             candidates)

Sorts nodes based on the weight of their paths. The weight is calculated every time a resolver runs.

Sorts nodes based on the weight of their paths. The weight is calculated every time
a resolver runs.
sourceraw docstring

with-resolver-cacheclj/s

(with-resolver-cache env)
(with-resolver-cache env cache*)
source

cljdoc is a website building & hosting documentation for Clojure/Script libraries

× close