2020-01-02 22:18:49 -05:00
|
|
|
from lbry.wallet.database import constraints_to_sql
|
2019-11-14 14:31:49 -05:00
|
|
|
|
|
|
|
CREATE_FULL_TEXT_SEARCH = """
|
|
|
|
create virtual table if not exists search using fts5(
|
|
|
|
claim_name, channel_name, title, description, author, tags,
|
|
|
|
content=claim, tokenize=porter
|
|
|
|
);
|
|
|
|
"""
|
|
|
|
|
|
|
|
FTS_ORDER_BY = "bm25(search, 4.0, 8.0, 1.0, 0.5, 1.0, 0.5)"
|
|
|
|
|
|
|
|
|
|
|
|
def fts_action_sql(claims=None, action='insert'):
|
|
|
|
select = {
|
|
|
|
'rowid': "claim.rowid",
|
|
|
|
'claim_name': "claim.normalized",
|
|
|
|
'channel_name': "channel.normalized",
|
|
|
|
'title': "claim.title",
|
|
|
|
'description': "claim.description",
|
|
|
|
'author': "claim.author",
|
|
|
|
'tags': "(select group_concat(tag, ' ') from tag where tag.claim_hash=claim.claim_hash)"
|
|
|
|
}
|
|
|
|
if action == 'delete':
|
2019-11-14 15:32:38 -05:00
|
|
|
select['search'] = '"delete"'
|
2019-11-14 14:31:49 -05:00
|
|
|
|
|
|
|
where, values = "", {}
|
|
|
|
if claims:
|
2019-12-07 18:13:13 -05:00
|
|
|
where, values = constraints_to_sql({'claim.claim_hash__in': claims})
|
2019-11-14 14:31:49 -05:00
|
|
|
where = 'WHERE '+where
|
|
|
|
|
|
|
|
return f"""
|
|
|
|
INSERT INTO search ({','.join(select.keys())})
|
|
|
|
SELECT {','.join(select.values())} FROM claim
|
|
|
|
LEFT JOIN claim as channel ON (claim.channel_hash=channel.claim_hash) {where}
|
|
|
|
""", values
|
|
|
|
|
|
|
|
|
2019-11-25 15:09:44 -03:00
|
|
|
def update_full_text_search(action, outputs, db, is_first_sync):
|
2019-11-14 14:31:49 -05:00
|
|
|
if is_first_sync:
|
|
|
|
return
|
|
|
|
if not outputs:
|
|
|
|
return
|
|
|
|
if action in ("before-delete", "before-update"):
|
|
|
|
db.execute(*fts_action_sql(outputs, 'delete'))
|
|
|
|
elif action in ("after-insert", "after-update"):
|
|
|
|
db.execute(*fts_action_sql(outputs, 'insert'))
|
|
|
|
else:
|
|
|
|
raise ValueError(f"Invalid action for updating full text search: '{action}'")
|
2019-11-25 15:09:44 -03:00
|
|
|
|
|
|
|
|
|
|
|
def first_sync_finished(db):
|
|
|
|
db.execute(*fts_action_sql())
|