Extract expiry calculation from KeyConfirmationQueue
This commit is contained in:
parent
e6619a660f
commit
abd3f923fb
4 changed files with 34 additions and 9 deletions
16
lacre/keymgmt.py
Normal file
16
lacre/keymgmt.py
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
"""Key management utilities."""
|
||||||
|
|
||||||
|
from datetime import datetime, timedelta
|
||||||
|
|
||||||
|
from lacre.config import get_item
|
||||||
|
|
||||||
|
|
||||||
|
def calculate_expiry_date(now: datetime) -> datetime:
|
||||||
|
"""Calculate date-time of key queue item expiry.
|
||||||
|
|
||||||
|
Given current timestamp and configuration item
|
||||||
|
[database]max_queue_hours, return a date-time object that should be
|
||||||
|
older than any key in our confirmation queue. If a key is older
|
||||||
|
than this threshold, we should remove it."""
|
||||||
|
max_hours = get_item('database', 'max_queue_hours', 1)
|
||||||
|
return now - timedelta(hours=max_hours)
|
|
@ -1,6 +1,6 @@
|
||||||
"""Lacre identity and key repositories."""
|
"""Lacre identity and key repositories."""
|
||||||
|
|
||||||
from datetime import timedelta
|
from datetime import datetime, timedelta
|
||||||
|
|
||||||
from sqlalchemy import create_engine, select, delete, and_, func
|
from sqlalchemy import create_engine, select, delete, and_, func
|
||||||
from sqlalchemy.exc import OperationalError
|
from sqlalchemy.exc import OperationalError
|
||||||
|
@ -173,12 +173,10 @@ class KeyConfirmationQueue:
|
||||||
with self._engine.connect() as conn:
|
with self._engine.connect() as conn:
|
||||||
return [e for e in conn.execute(seldel)]
|
return [e for e in conn.execute(seldel)]
|
||||||
|
|
||||||
def delete_expired_queue_items(self, when):
|
def delete_expired_queue_items(self, older_than: datetime):
|
||||||
max_hours = get_item('database', 'max_queue_hours', 1)
|
"""Remove keys that have been in queue before `older_than`."""
|
||||||
oldest = when - timedelta(hours=max_hours)
|
delq = delete(self._keys).where(self._keys.c.time < older_than)
|
||||||
|
LOG.debug('Deleting queue items older than %s: %s', repr(older_than), delq)
|
||||||
delq = delete(self._keys).where(self._keys.c.time < oldest)
|
|
||||||
LOG.debug('Deleting queue items older than %s: %s', repr(oldest), delq)
|
|
||||||
|
|
||||||
with self._engine.connect() as conn:
|
with self._engine.connect() as conn:
|
||||||
conn.execute(delq)
|
conn.execute(delq)
|
||||||
|
|
10
test/modules/test_keymgmt.py
Normal file
10
test/modules/test_keymgmt.py
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
import datetime
|
||||||
|
import lacre.keymgmt as km
|
||||||
|
|
||||||
|
class KeyManagementUtilitiesTest(unittest.TestCase):
|
||||||
|
def test_expiry_date_calculation(self):
|
||||||
|
ts = datetime.datetime(2024, 1, 1, 12, 0)
|
||||||
|
exp = km.calculate_expiry_date(ts)
|
||||||
|
self.assertEqual(exp, datetime.datetime(2024, 1, 1, 11, 0))
|
|
@ -25,6 +25,7 @@ import logging
|
||||||
import lacre
|
import lacre
|
||||||
import lacre.config as conf
|
import lacre.config as conf
|
||||||
from lacre.notify import notify
|
from lacre.notify import notify
|
||||||
|
from lacre.keymgmt import calculate_expiry_date
|
||||||
|
|
||||||
# Read configuration from /etc/lacre.conf
|
# Read configuration from /etc/lacre.conf
|
||||||
conf.load_config()
|
conf.load_config()
|
||||||
|
@ -84,8 +85,8 @@ def cleanup(key_dir, key_queue):
|
||||||
|
|
||||||
LOG.info('Deleted key for: %s', email)
|
LOG.info('Deleted key for: %s', email)
|
||||||
|
|
||||||
now = datetime.now()
|
expiry_date = calculate_expiry_date(datetime.now())
|
||||||
key_queue.delete_expired_queue_items(now)
|
key_queue.delete_expired_queue_items(expiry_date)
|
||||||
|
|
||||||
|
|
||||||
_validate_config()
|
_validate_config()
|
||||||
|
|
Loading…
Reference in a new issue