forked from jeffu/wfh-ninja
-
Notifications
You must be signed in to change notification settings - Fork 0
/
models.py
82 lines (64 loc) · 2.74 KB
/
models.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
#!/usr/bin/env python
from flask import *
from flask.ext.sqlalchemy import SQLAlchemy
from flask.ext.login import UserMixin
import simplejson as json
import datetime
db = SQLAlchemy()
class Quote(db.Model):
id = db.Column(db.Integer, primary_key=True)
text = db.Column(db.String(500))
conditions = db.Column(db.Text)
date_created = db.Column(db.DateTime)
view_count = db.Column(db.Integer)
ip = db.Column(db.String(15))
active = db.Column(db.Boolean)
def __init__(self, text, conditions, view_count, ip, active):
self.text = text
self.conditions = conditions
self.date_created = datetime.datetime.utcnow()
self.view_count = view_count
self.ip = ip
self.active = active
def __repr__(self):
return json.dumps({"id": self.id, "text": self.text, "conditions": self.conditions,
"date_created": self.date_created.isoformat(), "view_count": self.view_count, "ip": self.ip,
"active": self.active})
@property
def serialize(self):
return {"id": self.id, "text": self.text, "conditions": self.conditions,
"date_created": self.date_created.isoformat(), "view_count": self.view_count, "ip": self.ip,
"active": self.active}
class Vote(db.Model):
id = db.Column(db.Integer, primary_key=True)
ip = db.Column(db.String(15))
value = db.Column(db.Integer)
date_created = db.Column(db.DateTime)
quote_id = db.Column(db.Integer, db.ForeignKey('quote.id'))
def __init__(self, ip, value, quote_id):
self.ip = ip
self.value = value
self.date_created = datetime.datetime.utcnow()
self.quote_id = quote_id
def __repr__(self):
return json.dumps({"id": self.id, "ip": self.ip, "value": self.value, "date_created": self.date_created,
"quote_id": self.quote_id})
@property
def serialize(self):
return {"id": self.id, "ip": self.ip, "value": self.value, "date_created": self.date_created.isoformat(),
"quote_id": self.quote_id}
class User(db.Model, UserMixin):
__tablename__ = "users"
id = db.Column('user_id', db.Integer, primary_key=True)
email = db.Column('email', db.String(50), unique=True, index=True)
password = db.Column('password', db.String(10))
date_created = db.Column('date_created', db.DateTime)
def __init__(self, password, email):
self.password = password
self.email = email
self.date_created = datetime.datetime.utcnow()
def __repr__(self):
return '<User %r>' % (self.email)
@property
def serialize(self):
return {"email": self.email, "password": self.password, "date_created": self.date_created.isoformat()}