This repository has been archived on 2024-12-19. You can view files and clone it, but cannot push or open issues or pull requests.
PyBitmessage-2024-12-19/src/bitmessagekivy/kivy_helper_search.py

72 lines
2.7 KiB
Python
Raw Normal View History

2019-09-20 13:19:04 +02:00
"""
2019-12-12 15:38:07 +01:00
Sql queries for bitmessagekivy
2019-09-20 13:19:04 +02:00
"""
from helper_sql import sqlQuery
2019-12-23 15:17:23 +01:00
def search_sql(
xAddress="toaddress", account=None, folder="inbox", where=None,
what=None, unreadOnly=False, start_indx=0, end_indx=20):
2019-09-20 13:19:04 +02:00
"""Method helping for searching mails"""
# pylint: disable=too-many-arguments, too-many-branches
if what is not None and what != "":
what = "%" + what + "%"
else:
what = None
if folder == "sent" or folder == "draft":
2019-12-12 15:38:07 +01:00
sqlStatementBase = (
2019-12-23 15:17:23 +01:00
'''SELECT toaddress, fromaddress, subject, message, status,'''
''' ackdata, lastactiontime FROM sent ''')
elif folder == "addressbook":
sqlStatementBase = '''SELECT label, address From addressbook '''
else:
2019-12-12 15:38:07 +01:00
sqlStatementBase = (
2019-12-23 15:17:23 +01:00
'''SELECT folder, msgid, toaddress, message, fromaddress,'''
''' subject, received, read FROM inbox ''')
sqlStatementParts = []
sqlArguments = []
if account is not None:
if xAddress == 'both':
sqlStatementParts.append("(fromaddress = ? OR toaddress = ?)")
sqlArguments.append(account)
sqlArguments.append(account)
else:
sqlStatementParts.append(xAddress + " = ? ")
sqlArguments.append(account)
2019-09-20 13:19:04 +02:00
if folder != "addressbook":
if folder is not None:
if folder == "new":
folder = "inbox"
unreadOnly = True
sqlStatementParts.append("folder = ? ")
sqlArguments.append(folder)
else:
sqlStatementParts.append("folder != ?")
sqlArguments.append("trash")
if what is not None:
for colmns in where:
if len(where) > 1:
if where[0] == colmns:
filter_col = "(%s LIKE ?" % (colmns)
else:
filter_col += " or %s LIKE ? )" % (colmns)
else:
filter_col = "%s LIKE ?" % (colmns)
sqlArguments.append(what)
sqlStatementParts.append(filter_col)
if unreadOnly:
sqlStatementParts.append("read = 0")
2019-09-20 13:19:04 +02:00
if sqlStatementParts:
sqlStatementBase += "WHERE " + " AND ".join(sqlStatementParts)
2019-12-23 15:17:23 +01:00
# if folder in ("sent", "draft"):
2019-12-12 15:38:07 +01:00
if folder == "sent" or folder == "draft":
2019-12-23 15:17:23 +01:00
sqlStatementBase += \
"ORDER BY lastactiontime DESC limit {0}, {1}".format(
start_indx, end_indx)
elif folder == "inbox":
2019-12-23 15:17:23 +01:00
sqlStatementBase += \
"ORDER BY received DESC limit {0}, {1}".format(
start_indx, end_indx)
2019-12-12 15:38:07 +01:00
# elif folder == "addressbook":
# sqlStatementBase += " limit {0}, {1}".format(start_indx, end_indx)
2019-12-26 16:56:04 +01:00
return sqlQuery(sqlStatementBase, sqlArguments)