Project

General

Profile

Statistics
| Branch: | Tag: | Revision:

vigiboard / dashboard / model / bdd_dashboard / grouppermissions.py @ 805cc54a

History | View | Annotate | Download (1.07 KB)

1
# -*- coding: utf-8 -*-
2
"""Model For GroupPermissions Table"""
3

    
4
from sqlalchemy.orm import mapper, relation
5
from sqlalchemy import Table, ForeignKeyConstraint, Column
6
from sqlalchemy.types import Integer, String, Text, DateTime
7

    
8
from dashboard.model import metadata, Permission
9

    
10
from dashboard.model.bdd_dashboard import Groups
11

    
12
# Generation par SQLAutoCode
13
grouppermissions =  Table('grouppermissions', metadata,
14
            Column(u'groupname', String(length=100, convert_unicode=False, assert_unicode=None), primary_key=True, nullable=False),
15
            Column(u'idpermission', Integer(), primary_key=True, nullable=False),
16
            ForeignKeyConstraint([u'groupname'], [u'groups.name'], name=u'grouppermissions_ibfk_1'),
17
    )
18

    
19
# Classe a mapper
20

    
21
class GroupPermissions(object):
22
        def get_grp (self,user_p):
23
                events = DBSession.query(Groups).join(
24
                        ( GroupPermissions , Groups.name == GroupPermission.groupname ),
25
                        ( Permission , Permission.permission_id == GroupPermissions.idpermission )
26
                        ).filter(in_(Permission.permission_name,user_p))
27
                return events
28

    
29
mapper(GroupPermissions,grouppermissions)
30