From 5bda2541847f847a4ca77cb0c8c750ba95f488ed Mon Sep 17 00:00:00 2001 From: zadam Date: Sun, 31 Mar 2019 22:23:50 +0200 Subject: [PATCH] allow searching with noteId & fix combining fulltext and other conditions with OR --- src/services/build_search_query.js | 26 ++++++-------------------- src/services/parse_filters.js | 6 ++++++ src/services/protected_session.js | 2 +- 3 files changed, 13 insertions(+), 21 deletions(-) diff --git a/src/services/build_search_query.js b/src/services/build_search_query.js index cfdab626c..f81a6ff33 100644 --- a/src/services/build_search_query.js +++ b/src/services/build_search_query.js @@ -5,6 +5,7 @@ const VIRTUAL_ATTRIBUTES = [ "dateModified", "utcDateCreated", "utcDateModified", + "noteId", "isProtected", "title", "content", @@ -37,20 +38,11 @@ module.exports = function(filters, selectedColumns = 'notes.*') { const alias = "note_contents"; if (!(alias in joins)) { - joins[alias] = `JOIN note_contents ON note_contents.noteId = notes.noteId`; + joins[alias] = `LEFT JOIN note_contents ON note_contents.noteId = notes.noteId`; } accessor = `${alias}.${property}`; } - else if (property === 'text') { - const alias = "note_fulltext"; - - if (!(alias in joins)) { - joins[alias] = `JOIN note_fulltext ON note_fulltext.noteId = notes.noteId`; - } - - accessor = alias; - } else { accessor = "notes." + property; } @@ -92,17 +84,11 @@ module.exports = function(filters, selectedColumns = 'notes.*') { else if (filter.operator === '=' || filter.operator === '!=') { if (filter.name === 'text') { const safeSearchText = utils.sanitizeSql(filter.value); - let condition = accessor + ' ' + `MATCH '${safeSearchText}'`; + const not = filter.operator.includes("!") ? "NOT" : ""; - if (filter.operator.includes("!")) { - // not supported! - } - else if (orderBy.length === 0) { - // if there's a positive full text search and there's no defined order then order by rank - orderBy.push("rank"); - } - - where += condition; + // fulltext needs to use subselect because fulltext doesn't support OR operations at all + // which makes it impossible to combine more operations together + where += `notes.noteId ${not} IN (SELECT noteId FROM note_fulltext WHERE note_fulltext MATCH '${safeSearchText}')`; } else { where += `${accessor} ${filter.operator} ?`; diff --git a/src/services/parse_filters.js b/src/services/parse_filters.js index 6b53d06da..0ae1bba17 100644 --- a/src/services/parse_filters.js +++ b/src/services/parse_filters.js @@ -51,6 +51,12 @@ module.exports = function (searchText) { name: 'text', operator: '=', value: searchText + }, + { + relation: 'or', + name: 'noteId', + operator: '=', + value: searchText } ] } diff --git a/src/services/protected_session.js b/src/services/protected_session.js index fac369796..d79002b63 100644 --- a/src/services/protected_session.js +++ b/src/services/protected_session.js @@ -91,7 +91,7 @@ function decryptNoteRevision(hist) { } } catch (e) { - throw new Error(`Decryption failed for note ${hist.noteId}: ` + e.message + " " + e.stack); + throw new Error(`Decryption failed for note ${hist.noteId}, revision ${hist.noteRevisionId}: ` + e.message + " " + e.stack); } }