Statistics
| Branch: | Tag: | Revision:

root / snf-pithos-backend / pithos / backends / lib / sqlalchemy / quotaholder_serials.py @ 860c5d9c

History | View | Annotate | Download (3.7 kB)

1 6540c590 Sofia Papagiannaki
# Copyright 2011-2012 GRNET S.A. All rights reserved.
2 6540c590 Sofia Papagiannaki
#
3 6540c590 Sofia Papagiannaki
# Redistribution and use in source and binary forms, with or
4 6540c590 Sofia Papagiannaki
# without modification, are permitted provided that the following
5 6540c590 Sofia Papagiannaki
# conditions are met:
6 6540c590 Sofia Papagiannaki
#
7 6540c590 Sofia Papagiannaki
#   1. Redistributions of source code must retain the above
8 6540c590 Sofia Papagiannaki
#      copyright notice, this list of conditions and the following
9 6540c590 Sofia Papagiannaki
#      disclaimer.
10 6540c590 Sofia Papagiannaki
#
11 6540c590 Sofia Papagiannaki
#   2. Redistributions in binary form must reproduce the above
12 6540c590 Sofia Papagiannaki
#      copyright notice, this list of conditions and the following
13 6540c590 Sofia Papagiannaki
#      disclaimer in the documentation and/or other materials
14 6540c590 Sofia Papagiannaki
#      provided with the distribution.
15 6540c590 Sofia Papagiannaki
#
16 6540c590 Sofia Papagiannaki
# THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
17 6540c590 Sofia Papagiannaki
# OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18 6540c590 Sofia Papagiannaki
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 6540c590 Sofia Papagiannaki
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
20 6540c590 Sofia Papagiannaki
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21 6540c590 Sofia Papagiannaki
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22 6540c590 Sofia Papagiannaki
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
23 6540c590 Sofia Papagiannaki
# USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
24 6540c590 Sofia Papagiannaki
# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 6540c590 Sofia Papagiannaki
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
26 6540c590 Sofia Papagiannaki
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 6540c590 Sofia Papagiannaki
# POSSIBILITY OF SUCH DAMAGE.
28 6540c590 Sofia Papagiannaki
#
29 6540c590 Sofia Papagiannaki
# The views and conclusions contained in the software and
30 6540c590 Sofia Papagiannaki
# documentation are those of the authors and should not be
31 6540c590 Sofia Papagiannaki
# interpreted as representing official policies, either expressed
32 6540c590 Sofia Papagiannaki
# or implied, of GRNET S.A.
33 6540c590 Sofia Papagiannaki
34 6540c590 Sofia Papagiannaki
from sqlalchemy import Table, Column, MetaData
35 6540c590 Sofia Papagiannaki
from sqlalchemy.types import BigInteger
36 6540c590 Sofia Papagiannaki
from sqlalchemy.sql import select
37 6540c590 Sofia Papagiannaki
from sqlalchemy.exc import NoSuchTableError
38 6540c590 Sofia Papagiannaki
39 6540c590 Sofia Papagiannaki
from dbworker import DBWorker
40 6540c590 Sofia Papagiannaki
41 6540c590 Sofia Papagiannaki
def create_tables(engine):
42 6540c590 Sofia Papagiannaki
    metadata = MetaData()
43 6540c590 Sofia Papagiannaki
    columns = []
44 6540c590 Sofia Papagiannaki
    columns.append(Column('serial', BigInteger, primary_key=True))
45 613659fc Sofia Papagiannaki
    Table('qh_serials', metadata, *columns, mysql_engine='InnoDB')
46 613659fc Sofia Papagiannaki
47 6540c590 Sofia Papagiannaki
    metadata.create_all(engine)
48 6540c590 Sofia Papagiannaki
    return metadata.sorted_tables
49 6540c590 Sofia Papagiannaki
50 cb787cc4 Sofia Papagiannaki
class QuotaholderSerial(DBWorker):
51 cb787cc4 Sofia Papagiannaki
    """QuotaholderSerial keeps track of quota holder serials.
52 6540c590 Sofia Papagiannaki
    """
53 6540c590 Sofia Papagiannaki
54 6540c590 Sofia Papagiannaki
    def __init__(self, **params):
55 6540c590 Sofia Papagiannaki
        DBWorker.__init__(self, **params)
56 6540c590 Sofia Papagiannaki
        try:
57 6540c590 Sofia Papagiannaki
            metadata = MetaData(self.engine)
58 6a5ca445 Sofia Papagiannaki
            self.qh_serials = Table('qh_serials', metadata, autoload=True)
59 6540c590 Sofia Papagiannaki
        except NoSuchTableError:
60 6540c590 Sofia Papagiannaki
            tables = create_tables(self.engine)
61 6540c590 Sofia Papagiannaki
            map(lambda t: self.__setattr__(t.name, t), tables)
62 6540c590 Sofia Papagiannaki
63 6540c590 Sofia Papagiannaki
    def get_lower(self, serial):
64 6540c590 Sofia Papagiannaki
        """Return entries lower than serial."""
65 6540c590 Sofia Papagiannaki
66 6a5ca445 Sofia Papagiannaki
        s = select([self.qh_serials.c.serial])
67 6a5ca445 Sofia Papagiannaki
        s = s.where(self.qh_serials.c.serial < serial)
68 6540c590 Sofia Papagiannaki
        r = self.conn.execute(s)
69 6540c590 Sofia Papagiannaki
        rows = r.fetchall()
70 6540c590 Sofia Papagiannaki
        r.close()
71 6540c590 Sofia Papagiannaki
        return rows
72 613659fc Sofia Papagiannaki
73 613659fc Sofia Papagiannaki
    def lookup(self, serials):
74 e1e37cf9 Sofia Papagiannaki
        """Return the registered serials."""
75 613659fc Sofia Papagiannaki
76 613659fc Sofia Papagiannaki
        if not serials:
77 613659fc Sofia Papagiannaki
            return []
78 613659fc Sofia Papagiannaki
        s = select([self.qh_serials.c.serial])
79 613659fc Sofia Papagiannaki
        s = s.where(self.qh_serials.c.serial.in_(serials))
80 613659fc Sofia Papagiannaki
        r = self.conn.execute(s)
81 613659fc Sofia Papagiannaki
        rows = r.fetchall()
82 613659fc Sofia Papagiannaki
        r.close()
83 613659fc Sofia Papagiannaki
        return [row[0] for row in rows]
84 613659fc Sofia Papagiannaki
85 6540c590 Sofia Papagiannaki
    def insert_serial(self, serial):
86 6540c590 Sofia Papagiannaki
        """Insert a serial.
87 6540c590 Sofia Papagiannaki
        """
88 6540c590 Sofia Papagiannaki
89 6a5ca445 Sofia Papagiannaki
        s = self.qh_serials.insert()
90 6540c590 Sofia Papagiannaki
        r = self.conn.execute(s, serial=serial)
91 6540c590 Sofia Papagiannaki
        r.close()
92 613659fc Sofia Papagiannaki
93 613659fc Sofia Papagiannaki
    def insert_many(self, serials):
94 613659fc Sofia Papagiannaki
        """Insert multiple serials.
95 613659fc Sofia Papagiannaki
        """
96 613659fc Sofia Papagiannaki
97 613659fc Sofia Papagiannaki
        r = self.conn.execute(
98 613659fc Sofia Papagiannaki
            self.qh_serials.insert(),
99 613659fc Sofia Papagiannaki
            list({'serial':s} for s in serials)
100 613659fc Sofia Papagiannaki
        )
101 613659fc Sofia Papagiannaki
        r.close()
102 613659fc Sofia Papagiannaki
103 613659fc Sofia Papagiannaki
    def delete_many(self, serials):
104 613659fc Sofia Papagiannaki
        if not serials:
105 613659fc Sofia Papagiannaki
            return
106 613659fc Sofia Papagiannaki
        st = self.qh_serials.delete().where(
107 613659fc Sofia Papagiannaki
            self.qh_serials.c.serial.in_(serials)
108 613659fc Sofia Papagiannaki
        )
109 613659fc Sofia Papagiannaki
        self.conn.execute(st).close()