UNPKG

@jahed/sparql-engine

Version:

SPARQL query engine for servers and web browsers.

60 lines 2.35 kB
import { Wildcard } from "sparqljs"; import ExecutionContext from "../context/execution-context.js"; import ContextSymbols from "../context/symbols.js"; import { Pipeline } from "../pipeline/pipeline.js"; import StageBuilder from "./stage-builder.js"; /** * A ServiceStageBuilder is responsible for evaluation a SERVICE clause in a SPARQL query. */ export default class ServiceStageBuilder extends StageBuilder { /** * Build a {@link PipelineStage} to evaluate a SERVICE clause * @param source - Input {@link PipelineStage} * @param node - Service clause * @param options - Execution options * @return A {@link PipelineStage} used to evaluate a SERVICE clause */ async execute(source, node, context) { let subquery; if (node.patterns[0].type === "query") { subquery = node.patterns[0]; } else { subquery = { prefixes: context.getProperty(ContextSymbols.PREFIXES), queryType: "SELECT", variables: [new Wildcard()], type: "query", where: node.patterns, }; } const iri = node.name; if (!this.dataset.getDefaultGraph().iri.equals(iri) && !this.dataset.hasNamedGraph(iri)) { const graph = await this.dataset.createGraph(iri); this.dataset.addNamedGraph(graph); } let handler = undefined; if (node.silent) { handler = () => { return Pipeline.getInstance().empty(); }; } return Pipeline.getInstance().catch(await this._buildIterator(source, iri, subquery, context), handler); } /** * Returns a {@link PipelineStage} used to evaluate a SERVICE clause * @abstract * @param source - Input {@link PipelineStage} * @param iri - Iri of the SERVICE clause * @param subquery - Subquery to be evaluated * @param options - Execution options * @return A {@link PipelineStage} used to evaluate a SERVICE clause */ async _buildIterator(source, iri, subquery, context) { const opts = context.clone(); opts.defaultGraphs = [iri]; return this._builder._buildQueryPlan(subquery, opts, source); } } //# sourceMappingURL=service-stage-builder.js.map