From a869ebdad781ae9549681853f3581b7e315de444 Mon Sep 17 00:00:00 2001
From: J08nY
Date: Mon, 7 Aug 2017 19:58:20 +0200
Subject: Add some utility functions for config transforms.
---
src/mailman_pgp/archivers/local.py | 32 -------------------
src/mailman_pgp/archivers/local_maildir.py | 51 ++++++++++++++++++++++++++++++
src/mailman_pgp/archivers/local_mbox.py | 51 ++++++++++++++++++++++++++++++
src/mailman_pgp/config/mailman_pgp.cfg | 8 +++++
src/mailman_pgp/config/schema.cfg | 13 +++++---
src/mailman_pgp/database/__init__.py | 6 ++--
src/mailman_pgp/testing/mailman_pgp.cfg | 8 +++++
src/mailman_pgp/utils/config.py | 31 ++++++++++++++++++
8 files changed, 160 insertions(+), 40 deletions(-)
delete mode 100644 src/mailman_pgp/archivers/local.py
create mode 100644 src/mailman_pgp/archivers/local_maildir.py
create mode 100644 src/mailman_pgp/archivers/local_mbox.py
create mode 100644 src/mailman_pgp/utils/config.py
diff --git a/src/mailman_pgp/archivers/local.py b/src/mailman_pgp/archivers/local.py
deleted file mode 100644
index 04d9a22..0000000
--- a/src/mailman_pgp/archivers/local.py
+++ /dev/null
@@ -1,32 +0,0 @@
-# Copyright (C) 2017 Jan Jancar
-#
-# This file is a part of the Mailman PGP plugin.
-#
-# This program is free software; you can redistribute it and/or modify it under
-# the terms of the GNU General Public License as published by the Free
-# Software Foundation, either version 3 of the License, or (at your option)
-# any later version.
-#
-# This program is distributed in the hope that it will be useful, but WITHOUT
-# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-# more details.
-#
-# You should have received a copy of the GNU General Public License along with
-# this program. If not, see .
-
-"""
-Archives messages locally, encrypted (TBD how),
-similar to Mailman's prototype archiver.
-"""
-
-from mailman.interfaces.archiver import IArchiver
-from public import public
-from zope.interface import implementer
-
-
-@public
-@implementer(IArchiver)
-class LocalArchiver:
- """Local PGP enabled archiver."""
- pass
diff --git a/src/mailman_pgp/archivers/local_maildir.py b/src/mailman_pgp/archivers/local_maildir.py
new file mode 100644
index 0000000..31cb6e6
--- /dev/null
+++ b/src/mailman_pgp/archivers/local_maildir.py
@@ -0,0 +1,51 @@
+# Copyright (C) 2017 Jan Jancar
+#
+# This file is a part of the Mailman PGP plugin.
+#
+# This program is free software; you can redistribute it and/or modify it under
+# the terms of the GNU General Public License as published by the Free
+# Software Foundation, either version 3 of the License, or (at your option)
+# any later version.
+#
+# This program is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
+# more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# this program. If not, see .
+
+"""
+Archives messages to a maildir, locally, encrypted (TBD how),
+similar to Mailman's prototype archiver.
+"""
+
+from mailman.interfaces.archiver import IArchiver
+from public import public
+from zope.interface import implementer
+
+from mailman_pgp.model.list import PGPMailingList
+
+
+@public
+@implementer(IArchiver)
+class LocalMaildirArchiver:
+ """Local PGP enabled archiver."""
+
+ name = 'pgp-maildir-local'
+ is_enabled = False
+
+ def list_url(self, mlist):
+ """See `IArchiver`."""
+ return None
+
+ def permalink(self, mlist, msg):
+ """See `IArchiver`."""
+ return None
+
+ def archive_message(self, mlist, msg):
+ """See `IArchiver`."""
+ pgp_list = PGPMailingList.for_list(mlist)
+ if not pgp_list:
+ return None
+ return None
diff --git a/src/mailman_pgp/archivers/local_mbox.py b/src/mailman_pgp/archivers/local_mbox.py
new file mode 100644
index 0000000..2a08c4a
--- /dev/null
+++ b/src/mailman_pgp/archivers/local_mbox.py
@@ -0,0 +1,51 @@
+# Copyright (C) 2017 Jan Jancar
+#
+# This file is a part of the Mailman PGP plugin.
+#
+# This program is free software; you can redistribute it and/or modify it under
+# the terms of the GNU General Public License as published by the Free
+# Software Foundation, either version 3 of the License, or (at your option)
+# any later version.
+#
+# This program is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
+# more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# this program. If not, see .
+
+"""
+Archives messages to a mbox, locally, encrypted (TBD how),
+similar to Mailman's prototype archiver.
+"""
+
+from mailman.interfaces.archiver import IArchiver
+from public import public
+from zope.interface import implementer
+
+from mailman_pgp.model.list import PGPMailingList
+
+
+@public
+@implementer(IArchiver)
+class LocalMailboxArchiver:
+ """Local PGP enabled archiver."""
+
+ name = 'pgp-mbox-local'
+ is_enabled = False
+
+ def list_url(self, mlist):
+ """See `IArchiver`."""
+ return None
+
+ def permalink(self, mlist, msg):
+ """See `IArchiver`."""
+ return None
+
+ def archive_message(self, mlist, msg):
+ """See `IArchiver`."""
+ pgp_list = PGPMailingList.for_list(mlist)
+ if not pgp_list:
+ return None
+ return None
diff --git a/src/mailman_pgp/config/mailman_pgp.cfg b/src/mailman_pgp/config/mailman_pgp.cfg
index e975836..0828b3d 100644
--- a/src/mailman_pgp/config/mailman_pgp.cfg
+++ b/src/mailman_pgp/config/mailman_pgp.cfg
@@ -22,6 +22,14 @@
url: sqlite:////$DATA_DIR/pgp.db
+[archiving]
+# The directory where the local mbox archiver will save messages.
+mailbox_dir: $ARCHIVE_DIR/pgp/mbox
+
+# The directory where the local maildir archiver will save messages.
+maildir_dir: $ARCHIVE_DIR/pgp/maildir
+
+
[keydirs]
# Key directory used to store user public keys.
user_keydir: $DATA_DIR/pgp/user_keydir/
diff --git a/src/mailman_pgp/config/schema.cfg b/src/mailman_pgp/config/schema.cfg
index 085ab0a..feed0b6 100644
--- a/src/mailman_pgp/config/schema.cfg
+++ b/src/mailman_pgp/config/schema.cfg
@@ -18,15 +18,20 @@
# Schema of the mailman_pgp config.
[db]
-url: pathlib.Path
+url: mailman_pgp.utils.config.expandable_str
+
+[archiving]
+mailbox_dir: mailman_pgp.utils.config.expandable_path
+
+maildir_dir: mailman_pgp.utils.config.expandable_path
[keydirs]
-user_keydir: pathlib.Path
+user_keydir: mailman_pgp.utils.config.expandable_path
-list_keydir: pathlib.Path
+list_keydir: mailman_pgp.utils.config.expandable_path
-archive_keydir: pathlib.Path
+archive_keydir: mailman_pgp.utils.config.expandable_path
[keypairs]
diff --git a/src/mailman_pgp/database/__init__.py b/src/mailman_pgp/database/__init__.py
index 2bd1feb..a7f0c64 100644
--- a/src/mailman_pgp/database/__init__.py
+++ b/src/mailman_pgp/database/__init__.py
@@ -19,14 +19,13 @@
import logging
from contextlib import contextmanager
-from mailman.config import config as mailman_config
from mailman.database.transaction import transaction as mailman_transaction
from mailman.utilities.string import expand
from public import public
from sqlalchemy import create_engine
from sqlalchemy.orm import scoped_session, sessionmaker
-from mailman_pgp.config import config
+from mailman_pgp.config import config, mm_config
from mailman_pgp.model.base import Base
log = logging.getLogger('mailman.plugin.pgp.database')
@@ -37,8 +36,7 @@ class Database:
"""A SQLAlchemy database."""
def __init__(self):
- url = config.get('db', 'url')
- self._url = expand(url, None, mailman_config.paths)
+ self._url = config.get_value('db', 'url')
log.debug('Creating database at {}'.format(self._url))
self.engine = create_engine(self._url)
self.scoped_session = scoped_session(sessionmaker(bind=self.engine))
diff --git a/src/mailman_pgp/testing/mailman_pgp.cfg b/src/mailman_pgp/testing/mailman_pgp.cfg
index c85d38a..1ef8938 100644
--- a/src/mailman_pgp/testing/mailman_pgp.cfg
+++ b/src/mailman_pgp/testing/mailman_pgp.cfg
@@ -22,6 +22,14 @@
url: sqlite:////$DATA_DIR/pgp.db
+[archiving]
+# The directory where the local mbox archiver will save messages.
+mailbox_dir: $ARCHIVE_DIR/pgp/mbox
+
+# The directory where the local maildir archiver will save messages.
+maildir_dir: $ARCHIVE_DIR/pgp/maildir
+
+
[keydirs]
# Key directory used to store user public keys.
user_keydir: $DATA_DIR/pgp/user_keydir/
diff --git a/src/mailman_pgp/utils/config.py b/src/mailman_pgp/utils/config.py
new file mode 100644
index 0000000..3296379
--- /dev/null
+++ b/src/mailman_pgp/utils/config.py
@@ -0,0 +1,31 @@
+# Copyright (C) 2017 Jan Jancar
+#
+# This file is a part of the Mailman PGP plugin.
+#
+# This program is free software; you can redistribute it and/or modify it under
+# the terms of the GNU General Public License as published by the Free
+# Software Foundation, either version 3 of the License, or (at your option)
+# any later version.
+#
+# This program is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
+# more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# this program. If not, see .
+
+""""""
+import pathlib
+
+from mailman.utilities.string import expand
+
+from mailman_pgp.config import mm_config
+
+
+def expandable_str(value):
+ return expand(value, None, mm_config.paths)
+
+
+def expandable_path(value):
+ return pathlib.Path(expandable_str(value))
--
cgit v1.2.3-70-g09d2