Skip to content

Commit

Permalink
feat: allow minting after expiry
Browse files Browse the repository at this point in the history
  • Loading branch information
thesimplekid committed Oct 30, 2024
1 parent 661a6a1 commit 30752f1
Showing 1 changed file with 25 additions and 13 deletions.
38 changes: 25 additions & 13 deletions crates/cdk/src/mint/mint_nut04.rs
Original file line number Diff line number Diff line change
Expand Up @@ -205,9 +205,24 @@ impl Mint {
mint_quote.id,
request_lookup_id
);
self.localstore
.update_mint_quote_state(&mint_quote.id, MintQuoteState::Paid)
.await?;

let unix_time = unix_time();

if mint_quote.expiry < unix_time {
tracing::warn!(
"Mint quote {} paid at {} expired at {}",
mint_quote.id,
mint_quote.expiry,
unix_time
);
return Err(Error::ExpiredQuote(mint_quote.expiry, unix_time));
}

if mint_quote.state != MintQuoteState::Issued {
self.localstore
.update_mint_quote_state(&mint_quote.id, MintQuoteState::Paid)
.await?;
}
}
Ok(())
}
Expand All @@ -218,16 +233,13 @@ impl Mint {
&self,
mint_request: nut04::MintBolt11Request,
) -> Result<nut04::MintBolt11Response, Error> {
// Check quote is known and not expired
match self.localstore.get_mint_quote(&mint_request.quote).await? {
Some(quote) => {
if quote.expiry < unix_time() {
return Err(Error::ExpiredQuote(quote.expiry, unix_time()));
}
}
None => {
return Err(Error::UnknownQuote);
}
if self
.localstore
.get_mint_quote(&mint_request.quote)
.await?
.is_none()
{
return Err(Error::UnknownQuote);
}

let state = self
Expand Down

0 comments on commit 30752f1

Please sign in to comment.