Beispiel #1
0
class Keyword(db.Model):

    __tablename__ = 'keyword'
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(140), index=True, unique=True)
    count = db.Column(db.Integer, index=True)

    def __repr__(self):
        return '<Keyword #{}: {}>'.format(self.id, self.title)
Beispiel #2
0
class Continent(db.Model):

    __tablename__ = 'continent'
    id = db.Column(db.Integer, primary_key=True)
    alpha2 = db.Column(db.String(2), index=True, unique=True)
    title = db.Column(db.String(140))

    def __repr__(self):
        return '<Continent #{}: {}>'.format(self.id, self.title)
Beispiel #3
0
class MagicNumber(db.Model):

    __tablename__ = 'magic_number'
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(140), index=True, unique=True)
    count = db.Column(db.Integer)

    def __repr__(self):
        return '<MagicNumber #{}: {} ({})>'.format(self.id, self.title,
                                                   self.count)
Beispiel #4
0
class Group(db.Model):

    __tablename__ = 'group'
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(16))

    def default(self, role='user'):
        return self.query.filter_by(title=role).first()

    def __repr__(self):
        return '<Group #{}: {}>'.format(self.id, self.title)
Beispiel #5
0
class ContinentTranslation(db.Model):

    __tablename__ = 'continent_translation'
    id = db.Column(db.Integer, primary_key=True)
    language = db.Column(db.String(2), index=True)
    continent_id = db.Column(db.Integer, db.ForeignKey('continent.id'))
    continent = db.relationship('Continent', backref='translation')
    title = db.Column(db.String(140))

    def __repr__(self):
        return '<ContinentTranslation #{}: {}>'.format(self.id, self.title)
Beispiel #6
0
class Country(db.Model):

    __tablename__ = 'country'
    id = db.Column(db.Integer, primary_key=True)
    alpha2 = db.Column(db.String(2), index=True, unique=True)
    title = db.Column(db.String(140))
    continent_id = db.Column(db.Integer, db.ForeignKey('continent.id'))
    continent = db.relationship('Continent', backref='countries')

    def __repr__(self):
        return '<Country #{}: {}>'.format(self.id, self.title)
Beispiel #7
0
class User(db.Model, UserMixin):

    __tablename__ = 'user'
    id = db.Column(db.Integer, primary_key=True)
    email = db.Column(db.String(256), index=True, unique=True)
    name = db.Column(db.String(256))
    language = db.Column(db.String(2))
    group_id = db.Column(db.Integer, db.ForeignKey('group.id'))
    group = db.relationship('Group', backref='users')
    created_with = db.Column(db.String(16))
    created_at = db.Column(db.DateTime)
    last_seen = db.Column(db.DateTime)
    remember_me_token = db.Column(db.String(128))

    def __repr__(self):
        return '<User #{}: {}>'.format(self.id, self.name)

    def avatar(self, size):
        base_url = 'http://www.gravatar.com/avatar/'
        user_email = str(self.email)
        user_hash = md5(user_email.encode('utf_8')).hexdigest()
        return '{}{}?s={}'.format(base_url, user_hash, size)

    def valid_email(self):
        email_regex = re.compile(r'[\w+\-.]+@[A-Za-z\d\-.]+\.[A-Za-z]+')
        if email_regex.match(self.email):
            return True
        return False

    @staticmethod
    def get_token():
        return str(uuid4())

    def get_hash(self):
        return sha512(self.remember_me_token).hexdigest()

    def check_hash(self, hash):
        return hash == self.get_hash()
Beispiel #8
0
class Conference(db.Model):

    __tablename__ = 'conference'
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(140), index=True)
    place = db.Column(db.String(256), index=True)
    starts = db.Column(db.Date, index=True)
    ends = db.Column(db.Date, index=True)
    deadline = db.Column(db.Date, index=True)
    poster = db.Column(db.String(256))
    url = db.Column(db.String(256))
    email = db.Column(db.String(256))
    description = db.Column(db.Text())
    continent_id = db.Column(db.Integer, db.ForeignKey('continent.id'))
    country_id = db.Column(db.Integer, db.ForeignKey('country.id'))
    country = db.relationship('Country', backref='conferences')
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'))
    user = db.relationship('User', backref='conferences')
    keywords = db.relationship('Keyword',
                               secondary=conferences_keywords,
                               backref=' conferences')

    def __repr__(self):
        return '<Conference #{}: {}>'.format(self.id, self.title)
Beispiel #9
0
class Year(db.Model):

    __tablename__ = 'year'
    id = db.Column(db.Integer, primary_key=True)
    year = db.Column(db.SmallInteger, index=True, unique=True)
Beispiel #10
0
# coding: utf-8

import re
from findaconf import db
from flask.ext.login import UserMixin
from hashlib import md5, sha512
from os import urandom
from uuid import uuid4

conferences_keywords = db.Table(
    'conferences_keywords', db.metadata,
    db.Column('conference_id', db.Integer, db.ForeignKey('conference.id')),
    db.Column('keyword_id', db.Integer, db.ForeignKey('keyword.id')))


class Group(db.Model):

    __tablename__ = 'group'
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(16))

    def default(self, role='user'):
        return self.query.filter_by(title=role).first()

    def __repr__(self):
        return '<Group #{}: {}>'.format(self.id, self.title)


class User(db.Model, UserMixin):

    __tablename__ = 'user'