|
@ -66,7 +66,7 @@ pub struct Actor { |
|
|
|
|
|
|
|
|
impl Actor { |
|
|
impl Actor { |
|
|
#[allow(clippy::too_many_arguments)] |
|
|
#[allow(clippy::too_many_arguments)] |
|
|
pub async fn new( |
|
|
pub fn new( |
|
|
db: sqlx::SqlitePool, |
|
|
db: sqlx::SqlitePool, |
|
|
wallet: Wallet, |
|
|
wallet: Wallet, |
|
|
oracle_pk: schnorrsig::PublicKey, |
|
|
oracle_pk: schnorrsig::PublicKey, |
|
@ -74,30 +74,9 @@ impl Actor { |
|
|
order_feed_actor_inbox: watch::Sender<Option<Order>>, |
|
|
order_feed_actor_inbox: watch::Sender<Option<Order>>, |
|
|
send_to_maker: Address<send_to_socket::Actor<wire::TakerToMaker>>, |
|
|
send_to_maker: Address<send_to_socket::Actor<wire::TakerToMaker>>, |
|
|
monitor_actor: Address<monitor::Actor<Actor>>, |
|
|
monitor_actor: Address<monitor::Actor<Actor>>, |
|
|
cfds: Vec<Cfd>, |
|
|
|
|
|
oracle_actor: Address<oracle::Actor<Actor, monitor::Actor<Actor>>>, |
|
|
oracle_actor: Address<oracle::Actor<Actor, monitor::Actor<Actor>>>, |
|
|
) -> Result<Self> { |
|
|
) -> Self { |
|
|
for dlc in cfds.iter().filter_map(|cfd| Cfd::pending_open_dlc(cfd)) { |
|
|
Self { |
|
|
let txid = wallet.try_broadcast_transaction(dlc.lock.0.clone()).await?; |
|
|
|
|
|
|
|
|
|
|
|
tracing::info!("Lock transaction published with txid {}", txid); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
for cfd in cfds.iter().filter(|cfd| Cfd::is_must_refund(cfd)) { |
|
|
|
|
|
let signed_refund_tx = cfd.refund_tx()?; |
|
|
|
|
|
let txid = wallet.try_broadcast_transaction(signed_refund_tx).await?; |
|
|
|
|
|
|
|
|
|
|
|
tracing::info!("Refund transaction published on chain: {}", txid); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
for cfd in cfds.iter().filter(|cfd| Cfd::is_pending_commit(cfd)) { |
|
|
|
|
|
let signed_commit_tx = cfd.commit_tx()?; |
|
|
|
|
|
let txid = wallet.try_broadcast_transaction(signed_commit_tx).await?; |
|
|
|
|
|
|
|
|
|
|
|
tracing::info!("Commit transaction published on chain: {}", txid); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Ok(Self { |
|
|
|
|
|
db, |
|
|
db, |
|
|
wallet, |
|
|
wallet, |
|
|
oracle_pk, |
|
|
oracle_pk, |
|
@ -108,7 +87,7 @@ impl Actor { |
|
|
setup_state: SetupState::None, |
|
|
setup_state: SetupState::None, |
|
|
latest_announcement: None, |
|
|
latest_announcement: None, |
|
|
_oracle_actor: oracle_actor, |
|
|
_oracle_actor: oracle_actor, |
|
|
}) |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
async fn handle_take_offer(&mut self, order_id: OrderId, quantity: Usd) -> Result<()> { |
|
|
async fn handle_take_offer(&mut self, order_id: OrderId, quantity: Usd) -> Result<()> { |
|
|