blockstream-satellite-api/server/models.py
Blockstream Satellite 5882fddc49 Support retransmission of unconfirmed orders
This change implements a mechanism to retransmit orders if some of the
order's selected regions do not confirm transmission in due time. It
adds a worker to repeatedly check the orders and determine if they need
retransmission. Such orders will be added to a new table named
tx_retries. The tx_start function now first checks if there are regular
new paid orders to transmit. If not, it will check the retransmission
table and retransmit an order from there if one is available.

This patch also introduces a new order state called "retranmission". The
order enters this state while waiting for retransmission.
2021-12-28 10:01:04 -03:00

68 lines
2.6 KiB
Python

from sqlalchemy.sql import func
from database import db
class Order(db.Model):
__tablename__ = 'orders'
id = db.Column(db.Integer, primary_key=True)
bid = db.Column(db.Integer, default=0)
message_size = db.Column(db.Integer, nullable=False)
bid_per_byte = db.Column(db.Float, default=0) # TODO: remove (redundant)
message_digest = db.Column(db.String(64), nullable=False)
status = db.Column(db.Integer)
uuid = db.Column(db.String(36), nullable=False)
created_at = db.Column(db.DateTime, default=func.now())
cancelled_at = db.Column(db.DateTime)
started_transmission_at = db.Column(db.DateTime)
ended_transmission_at = db.Column(db.DateTime)
tx_seq_num = db.Column(db.Integer, unique=True)
unpaid_bid = db.Column(db.Integer, nullable=False)
region_code = db.Column(db.Integer)
invoices = db.relationship('Invoice', backref='order', lazy=True)
class Invoice(db.Model):
__tablename__ = 'invoices'
id = db.Column(db.Integer, primary_key=True)
lid = db.Column(db.String(100), nullable=False)
invoice = db.Column(db.String(1024), nullable=False)
paid_at = db.Column(db.DateTime)
created_at = db.Column(db.DateTime, default=func.now())
order_id = db.Column(db.Integer, db.ForeignKey('orders.id'))
status = db.Column(db.Integer)
amount = db.Column(db.Integer)
expires_at = db.Column(db.DateTime, nullable=False)
class TxConfirmation(db.Model):
__tablename__ = 'tx_confirmations'
id = db.Column(db.Integer, primary_key=True)
created_at = db.Column(db.DateTime, default=func.now())
order_id = db.Column(db.Integer,
db.ForeignKey('orders.id'),
nullable=False)
region_id = db.Column(db.Integer, nullable=False)
presumed = db.Column(db.Boolean, default=False)
class RxConfirmation(db.Model):
__tablename__ = 'rx_confirmations'
id = db.Column(db.Integer, primary_key=True)
created_at = db.Column(db.DateTime, default=func.now())
order_id = db.Column(db.Integer,
db.ForeignKey('orders.id'),
nullable=False)
region_id = db.Column(db.Integer, nullable=False)
presumed = db.Column(db.Boolean, default=False)
class TxRetry(db.Model):
__tablename__ = 'tx_retries'
id = db.Column(db.Integer, primary_key=True)
order_id = db.Column(db.Integer, db.ForeignKey('orders.id'))
last_attempt = db.Column(db.DateTime)
retry_count = db.Column(db.Integer, default=0)
region_code = db.Column(db.Integer)
pending = db.Column(db.Boolean, default=True)
created_at = db.Column(db.DateTime, default=func.now())