Prototype website for VPN service, Bitcoin payments via the Blockchain.info API
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

55 lines
2.1 KiB

10 years ago
  1. from app import db
  2. from flask.ext.sqlalchemy import SQLAlchemy
  3. from flask.ext.security import UserMixin, RoleMixin
  4. roles_users = db.Table('roles_users',
  5. db.Column('user_id', db.Integer(), db.ForeignKey('user.id')),
  6. db.Column('role_id', db.Integer(), db.ForeignKey('role.id')))
  7. class Role(db.Model, RoleMixin):
  8. id = db.Column(db.Integer(), primary_key=True)
  9. name = db.Column(db.String(80), unique=True)
  10. description = db.Column(db.String(255))
  11. class User(db.Model, UserMixin):
  12. id = db.Column(db.Integer, primary_key=True)
  13. email = db.Column(db.String(255), unique=True)
  14. password = db.Column(db.String(255))
  15. active = db.Column(db.Boolean())
  16. confirmed_at = db.Column(db.DateTime())
  17. roles = db.relationship('Role', secondary=roles_users, backref=db.backref('users', lazy='dynamic'))
  18. tickets = db.relationship('Ticket', backref='creator', lazy='dynamic')
  19. invoices = db.relationship('Invoice', backref='customer', lazy='dynamic')
  20. def __repr__(self):
  21. return '<User %r>' % (self.email)
  22. class Ticket(db.Model):
  23. id = db.Column(db.Integer, primary_key=True)
  24. subject = db.Column(db.String(140), unique=True)
  25. body = db.Column(db.String(2000))
  26. created = db.Column(db.DateTime)
  27. timestamp = db.Column(db.DateTime)
  28. user_id = db.Column(db.Integer, db.ForeignKey('user.id'))
  29. def __repr__(self):
  30. return '<Ticket %r>' % (self.subject)
  31. class Invoice(db.Model):
  32. id = db.Column(db.Integer, primary_key=True)
  33. is_confirmed = db.Column(db.Boolean())
  34. paid = db.Column(db.Boolean())
  35. datepaid = db.Column(db.DateTime)
  36. datecreated = db.Column(db.DateTime)
  37. dateends = db.Column(db.DateTime)
  38. total_btc = db.Column(db.Float)
  39. exchange_rate_when_paid = db.Column(db.Float)
  40. address = db.Column(db.String(34))
  41. confirmations = db.Column(db.Integer)
  42. transaction_hash = db.Column(db.String)
  43. input_transaction_hash = db.Column(db.String)
  44. value_paid = db.Column(db.Float)
  45. user_id = db.Column(db.Integer, db.ForeignKey('user.id'))
  46. def __repr__(self):
  47. return '<Invoice %r>' % (self.id)