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

51 lines
1.9 KiB
Python
Raw Normal View History

2019-10-07 15:58:12 +02:00
"""
2019-10-09 15:27:51 +02:00
Insert values into sent table
2019-10-07 15:58:12 +02:00
"""
2020-11-05 21:32:13 +01:00
import time
import uuid
2020-11-05 21:32:13 +01:00
from addresses import decodeAddress
from bmconfigparser import BMConfigParser
2020-11-05 21:32:13 +01:00
from helper_ackPayload import genAckPayload
2019-12-23 10:49:03 +01:00
from helper_sql import sqlExecute
2019-10-09 15:27:51 +02:00
2020-11-09 16:15:28 +01:00
# pylint: disable=too-many-arguments
def insert(msgid=None, toAddress=None, fromAddress=None, subject=None, message=None,
status=None, ripe=None, ackdata=None, sentTime=None, lastActionTime=None,
sleeptill=None, retryNumber=None, encoding=None, ttl=None, folder='sent',
is_testcase=False):
2019-10-09 15:27:51 +02:00
"""Perform an insert into the `sent` table"""
# pylint: disable=unused-variable
2020-11-09 16:15:28 +01:00
# pylint: disable-msg=too-many-locals
msgid = msgid if msgid else uuid.uuid4().bytes
if not ripe or not ackdata:
new_status, addressVersionNumber, streamNumber, new_ripe = decodeAddress(toAddress)
if not ripe:
ripe = new_ripe
if not ackdata:
stealthLevel = BMConfigParser().safeGetInt(
'bitmessagesettings', 'ackstealthlevel')
new_ackdata = genAckPayload(streamNumber, stealthLevel)
ackdata = new_ackdata
sentTime = sentTime if sentTime else int(time.time()) # sentTime (this doesn't change)
2020-11-09 16:15:28 +01:00
lastActionTime = lastActionTime if lastActionTime else int(time.time())
sleeptill = sleeptill if sleeptill else 0 # sleepTill time. This will get set when the POW gets done.
2020-11-09 16:15:28 +01:00
status = status if status else 'msgqueued'
retryNumber = retryNumber if retryNumber else 0
encoding = encoding if encoding else 2
ttl = ttl if ttl else BMConfigParser().getint('bitmessagesettings', 'ttl')
t = (msgid, toAddress, ripe, fromAddress, subject, message, ackdata,
sentTime, lastActionTime, sleeptill, status, retryNumber, folder,
encoding, ttl)
2015-03-09 07:35:32 +01:00
sqlExecute('''INSERT INTO sent VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)''', *t)
2020-11-05 21:32:13 +01:00
return t if is_testcase else None