From f6eaa70444e76504bb161cb8d0ecfe061ea7a1f8 Mon Sep 17 00:00:00 2001 From: Anudeep Tubati <40491005+NeuralFlux@users.noreply.github.com> Date: Tue, 6 Aug 2024 12:06:00 -0400 Subject: [PATCH] fix: added original curies to results as `query_id` (#204) * fix: added original curies to results as `query_id` * fix: replaced redundant map with forEach --- src/graph/kg_node.ts | 5 +++++ src/index.ts | 15 +++++++++++++++ 2 files changed, 20 insertions(+) diff --git a/src/graph/kg_node.ts b/src/graph/kg_node.ts index 60dac19f..ff338c5d 100644 --- a/src/graph/kg_node.ts +++ b/src/graph/kg_node.ts @@ -8,12 +8,14 @@ export interface KGNodeInfo { curies: string[]; primaryCurie: string; qNodeID: string; + originalCurie?: string; } export default class KGNode { id: string; primaryCurie: string; qNodeID: string; + originalCurie: string; curies: string[]; names: string[]; semanticType: string[]; @@ -36,6 +38,9 @@ export default class KGNode { this.targetNodes = new Set(); this.sourceQNodeIDs = new Set(); this.targetQNodeIDs = new Set(); + + // store original curie to output `query_id bte#815` + this.originalCurie = info.originalCurie; } addSourceNode(kgNodeID: string): void { diff --git a/src/index.ts b/src/index.ts index 95751de3..54d752c1 100644 --- a/src/index.ts +++ b/src/index.ts @@ -318,6 +318,18 @@ export default class TRAPIQueryHandler { this.finalizedResults = fixedResults; } + appendOriginalCuriesToResults(results: TrapiResult[]): void { + results.forEach(result => { + Object.entries(result.node_bindings).forEach(([_, bindings]) => { + bindings.forEach(binding => { + if (this.bteGraph.nodes[binding.id].originalCurie && this.bteGraph.nodes[binding.id].originalCurie !== binding.id) { + binding.query_id = this.bteGraph.nodes[binding.id].originalCurie; + } + }) + }) + }) + } + async addQueryNodes(): Promise { const qNodeIDsByOriginalID: Map = new Map(); const curiesToResolve = [ @@ -339,6 +351,7 @@ export default class TRAPIQueryHandler { this.bteGraph.nodes[resolvedEntity.primaryID] = new KGNode(resolvedEntity.primaryID, { primaryCurie: resolvedEntity.primaryID, qNodeID: qNodeIDsByOriginalID[originalCurie], + originalCurie: originalCurie, curies: resolvedEntity.equivalentIDs, names: resolvedEntity.labelAliases, semanticType: category ? [category] : ['biolink:NamedThing'], @@ -702,6 +715,8 @@ export default class TRAPIQueryHandler { this.createSubclassSupportGraphs(); // prune bteGraph this.bteGraph.prune(this.finalizedResults, this.auxGraphs); + // add original curies to results + this.appendOriginalCuriesToResults(this.finalizedResults); this.bteGraph.notify(); // Attempt to enrich results with PFOCR figures