mirror of
https://github.com/Blockstream/satellite-api.git
synced 2025-03-13 03:09:53 +01:00
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.
68 lines
2.6 KiB
Python
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())
|