mirror of
https://github.com/zadam/trilium.git
synced 2025-01-15 19:51:57 +08:00
full text search should look into link URLs as well, closes #2412
This commit is contained in:
parent
9d18bebb13
commit
263b7a84bb
2 changed files with 38 additions and 18 deletions
|
@ -8,6 +8,7 @@ const protectedSessionService = require('../../protected_session');
|
|||
const striptags = require('striptags');
|
||||
const utils = require("../../utils");
|
||||
|
||||
// FIXME: create common subclass with NoteContentUnprotectedFulltextExp to avoid duplication
|
||||
class NoteContentProtectedFulltextExp extends Expression {
|
||||
constructor(operator, tokens, raw) {
|
||||
super();
|
||||
|
@ -46,15 +47,7 @@ class NoteContentProtectedFulltextExp extends Expression {
|
|||
continue;
|
||||
}
|
||||
|
||||
content = utils.normalize(content);
|
||||
|
||||
if (type === 'text' && mime === 'text/html') {
|
||||
if (!this.raw && content.length < 20000) { // striptags is slow for very large notes
|
||||
content = striptags(content);
|
||||
}
|
||||
|
||||
content = content.replace(/ /g, ' ');
|
||||
}
|
||||
content = this.preprocessContent(content, type, mime);
|
||||
|
||||
if (!this.tokens.find(token => !content.includes(token))) {
|
||||
resultNoteSet.add(becca.notes[noteId]);
|
||||
|
@ -63,6 +56,23 @@ class NoteContentProtectedFulltextExp extends Expression {
|
|||
|
||||
return resultNoteSet;
|
||||
}
|
||||
|
||||
preprocessContent(content, type, mime) {
|
||||
content = utils.normalize(content.toString());
|
||||
|
||||
if (type === 'text' && mime === 'text/html') {
|
||||
if (!this.raw && content.length < 20000) { // striptags is slow for very large notes
|
||||
// allow link to preserve URLs: https://github.com/zadam/trilium/issues/2412
|
||||
content = striptags(content, ['a']);
|
||||
|
||||
// at least the closing tag can be easily stripped
|
||||
content = content.replace(/<\/a>/ig, "");
|
||||
}
|
||||
|
||||
content = content.replace(/ /g, ' ');
|
||||
}
|
||||
return content;
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = NoteContentProtectedFulltextExp;
|
||||
|
|
|
@ -6,6 +6,7 @@ const becca = require('../../../becca/becca');
|
|||
const striptags = require('striptags');
|
||||
const utils = require("../../utils");
|
||||
|
||||
// FIXME: create common subclass with NoteContentProtectedFulltextExp to avoid duplication
|
||||
class NoteContentUnprotectedFulltextExp extends Expression {
|
||||
constructor(operator, tokens, raw) {
|
||||
super();
|
||||
|
@ -32,15 +33,7 @@ class NoteContentUnprotectedFulltextExp extends Expression {
|
|||
continue;
|
||||
}
|
||||
|
||||
content = utils.normalize(content.toString());
|
||||
|
||||
if (type === 'text' && mime === 'text/html') {
|
||||
if (!this.raw && content.length < 20000) { // striptags is slow for very large notes
|
||||
content = striptags(content);
|
||||
}
|
||||
|
||||
content = content.replace(/ /g, ' ');
|
||||
}
|
||||
content = this.preprocessContent(content, type, mime);
|
||||
|
||||
if (!this.tokens.find(token => !content.includes(token))) {
|
||||
resultNoteSet.add(becca.notes[noteId]);
|
||||
|
@ -49,6 +42,23 @@ class NoteContentUnprotectedFulltextExp extends Expression {
|
|||
|
||||
return resultNoteSet;
|
||||
}
|
||||
|
||||
preprocessContent(content, type, mime) {
|
||||
content = utils.normalize(content.toString());
|
||||
|
||||
if (type === 'text' && mime === 'text/html') {
|
||||
if (!this.raw && content.length < 20000) { // striptags is slow for very large notes
|
||||
// allow link to preserve URLs: https://github.com/zadam/trilium/issues/2412
|
||||
content = striptags(content, ['a']);
|
||||
|
||||
// at least the closing tag can be easily stripped
|
||||
content = content.replace(/<\/a>/ig, "");
|
||||
}
|
||||
|
||||
content = content.replace(/ /g, ' ');
|
||||
}
|
||||
return content;
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = NoteContentUnprotectedFulltextExp;
|
||||
|
|
Loading…
Reference in a new issue