diff --git a/src/batch_edge_query.js b/src/batch_edge_query.js index 1fb0e5f4..693991db 100644 --- a/src/batch_edge_query.js +++ b/src/batch_edge_query.js @@ -4,6 +4,7 @@ const NodesUpdateHandler = require('./update_nodes'); const debug = require('debug')('biothings-explorer-trapi:batch_edge_query'); const CacheHandler = require('./cache_handler'); const utils = require('./utils'); +const LogEntry = require('./log_entry'); module.exports = class BatchEdgeQueryHandler { constructor(kg, resolveOutputIDs = true) { @@ -50,19 +51,47 @@ module.exports = class BatchEdgeQueryHandler { */ async _postQueryFilter(response) { try { - const filtered = response.filter((item) => { - let edge_predicate = item['$edge_metadata']['predicate']; - let predicate_filters = item['$edge_metadata']['trapi_qEdge_obj']['qEdge']['predicate']; - //remove prefix from filter list to match predicate name format - predicate_filters = predicate_filters.map((item) => utils.removeBioLinkPrefix(item)); - //compare edge predicate to filter list - if (predicate_filters.includes(edge_predicate)) { + const filtered = response.filter(item => { + debug(`ITEM ${JSON.stringify(item)}`); + if ( + 'predicate' in item['$edge_metadata']['trapi_qEdge_obj']['qEdge']&& + 'expanded_predicates' in item['$edge_metadata']['trapi_qEdge_obj']['qEdge'] + ) { + let edge_predicate = item['$edge_metadata']['predicate']; + let predicate_filters = []; + predicate_filters = item['$edge_metadata']['trapi_qEdge_obj']['qEdge']['expanded_predicates']; + if (predicate_filters) { + //add query predicate to the expanded list + predicate_filters.concat(edge_predicate); + //remove prefix from filter list to match predicate name format + predicate_filters = predicate_filters.map((item) => utils.removeBioLinkPrefix(item)); + //compare edge predicate to filter list + this.logs.push( + new LogEntry('DEBUG', null, `query_graph_handler: Current edge post-query predicate restriction includes: ${JSON.stringify(predicate_filters)}`).getLog() + ); + if (predicate_filters.includes(edge_predicate)) { + return item; + } + }else{ + // No predicate restriction on this edge, just add to results + return item + } + }else{ + // No predicate restriction on this edge, just add to results return item; } }); + // filter result debug(`Filtered results from ${response.length} down to ${filtered.length} results`); - return filtered; + this.logs.push( + new LogEntry('DEBUG', null, `query_graph_handler: Total number of results returned for this query is ${response.length}.`).getLog() + ); + this.logs.push( + new LogEntry('DEBUG', null, `query_graph_handler: Successfully applied post-query predicate restriction with ${filtered.length} results.`).getLog() + ); + return filtered } catch (error) { + // in case of rare failure return all debug(`Failed to filter ${response.length} results due to ${error}`); return response; } diff --git a/src/query_results.js b/src/query_results.js index a5ffe94a..0cda5704 100644 --- a/src/query_results.js +++ b/src/query_results.js @@ -42,6 +42,8 @@ module.exports = class QueryResult { this.results.push({ node_bindings: this._createNodeBindings(record), edge_bindings: this._createEdgeBindings(record), + //default score issue #200 - TODO: turn to evaluating module eventually + score: "1.0" }); }); }