1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000
1.2 +++ b/imiptools/stores/database/postgresql.py Thu Mar 10 01:43:31 2016 +0100
1.3 @@ -0,0 +1,49 @@
1.4 +#!/usr/bin/env python
1.5 +
1.6 +"""
1.7 +A PostgreSQL database store of calendar data.
1.8 +
1.9 +Copyright (C) 2016 Paul Boddie <paul@boddie.org.uk>
1.10 +
1.11 +This program is free software; you can redistribute it and/or modify it under
1.12 +the terms of the GNU General Public License as published by the Free Software
1.13 +Foundation; either version 3 of the License, or (at your option) any later
1.14 +version.
1.15 +
1.16 +This program is distributed in the hope that it will be useful, but WITHOUT
1.17 +ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
1.18 +FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
1.19 +details.
1.20 +
1.21 +You should have received a copy of the GNU General Public License along with
1.22 +this program. If not, see <http://www.gnu.org/licenses/>.
1.23 +"""
1.24 +
1.25 +from imiptools.stores.database.common import DatabaseStore, DatabaseJournal
1.26 +import psycopg2
1.27 +
1.28 +class Store(DatabaseStore):
1.29 +
1.30 + "A PostgreSQL database store of calendar objects and free/busy data."
1.31 +
1.32 + def __init__(self, store_dir):
1.33 +
1.34 + "Interpret 'store_dir' as a connection string."
1.35 +
1.36 + connection = psycopg2.connect(store_dir)
1.37 + connection.autocommit = True
1.38 + DatabaseStore.__init__(self, connection, psycopg2.paramstyle)
1.39 +
1.40 +class Journal(DatabaseJournal):
1.41 +
1.42 + "A PostgreSQL journal system supporting quotas."
1.43 +
1.44 + def __init__(self, store_dir):
1.45 +
1.46 + "Interpret 'store_dir' as a connection string."
1.47 +
1.48 + connection = psycopg2.connect(store_dir)
1.49 + connection.autocommit = True
1.50 + DatabaseJournal.__init__(self, connection, psycopg2.paramstyle)
1.51 +
1.52 +# vim: tabstop=4 expandtab shiftwidth=4