forget-cancellare-vecchi-toot/model.py

62 lines
2.0 KiB
Python
Raw Normal View History

2017-07-25 10:10:44 +02:00
from datetime import datetime
2017-07-25 09:52:24 +02:00
from app import db
2017-07-27 00:35:53 +02:00
from twitter import Twitter, OAuth
import secrets
2017-07-27 00:35:53 +02:00
2017-07-25 10:10:44 +02:00
class TimestampMixin(object):
created_at = db.Column(db.DateTime, server_default=db.func.now())
updated_at = db.Column(db.DateTime, server_default=db.func.now(), onupdate=db.func.now())
2017-07-25 09:52:24 +02:00
2017-07-27 00:35:53 +02:00
def touch(self):
self.updated_at=db.func.now()
2017-07-25 09:52:24 +02:00
2017-07-25 10:10:44 +02:00
class Account(db.Model, TimestampMixin):
2017-07-27 00:35:53 +02:00
__tablename__ = 'accounts'
remote_id = db.Column(db.String, primary_key=True)
2017-07-25 09:52:24 +02:00
2017-07-27 00:35:53 +02:00
# policy_enabled = db.Column(db.Boolean, server_default='FALSE', nullable=False)
# policy_keep_younger = db.Column(db.Interval)
# policy_keep_latest = db.Column(db.Integer)
# policy_delete_every = db.Column(db.Interval)
# policy_ignore_favourites = db.Column(db.Boolean, server_default='TRUE')
2017-07-25 09:52:24 +02:00
2017-07-27 00:35:53 +02:00
remote_display_name = db.Column(db.String)
2017-07-29 12:01:32 +02:00
remote_screen_name = db.Column(db.String)
2017-07-27 00:35:53 +02:00
remote_avatar_url = db.Column(db.String)
2017-07-28 12:48:00 +02:00
last_fetch = db.Column(db.DateTime, server_default='epoch')
2017-07-27 20:20:59 +02:00
# backref: tokens
2017-07-27 20:20:59 +02:00
2017-07-29 12:01:32 +02:00
def __repr__(self):
return f"<Account({self.remote_id}, {self.remote_screen_name}, {self.remote_display_name})>"
2017-07-27 00:35:53 +02:00
class OAuthToken(db.Model, TimestampMixin):
__tablename__ = 'oauth_tokens'
token = db.Column(db.String, primary_key=True)
token_secret = db.Column(db.String, nullable=False)
2017-07-27 00:35:53 +02:00
remote_id = db.Column(db.String, db.ForeignKey('accounts.remote_id'))
account = db.relationship(Account, backref=db.backref('tokens', order_by=lambda: db.desc(OAuthToken.created_at)))
2017-07-25 09:52:24 +02:00
class Session(db.Model, TimestampMixin):
__tablename__ = 'sessions'
id = db.Column(db.String, primary_key=True, default=lambda: secrets.token_urlsafe())
2017-07-27 20:20:59 +02:00
account_id = db.Column(db.String, db.ForeignKey('accounts.remote_id'))
account = db.relationship(Account, lazy='joined')
2017-07-27 20:20:59 +02:00
class Post(db.Model, TimestampMixin):
__tablename__ = 'posts'
remote_id = db.Column(db.String, primary_key=True)
body = db.Column(db.String)
author_id = db.Column(db.String, db.ForeignKey('accounts.remote_id'))
author = db.relationship(Account)