darkfi_money_contract/client/
token_mint_v1.rs1use darkfi::{
20 zk::{halo2::Value, Proof, ProvingKey, Witness, ZkCircuit},
21 zkas::ZkBinary,
22 Result,
23};
24use darkfi_sdk::pasta::pallas;
25use log::debug;
26use rand::rngs::OsRng;
27
28use crate::model::{CoinAttributes, MoneyTokenMintParamsV1, TokenAttributes};
29
30pub struct TokenMintCallDebris {
31 pub params: MoneyTokenMintParamsV1,
32 pub proofs: Vec<Proof>,
33}
34
35pub struct TokenMintCallBuilder {
37 pub coin_attrs: CoinAttributes,
38 pub token_attrs: TokenAttributes,
39
40 pub mint_zkbin: ZkBinary,
42 pub mint_pk: ProvingKey,
44}
45
46impl TokenMintCallBuilder {
47 pub fn build(&self) -> Result<TokenMintCallDebris> {
48 debug!(target: "contract::money::client::token_mint", "Building Money::TokenMintV1 contract call");
49 let (public_x, public_y) = self.coin_attrs.public_key.xy();
50
51 let prover_witnesses = vec![
52 Witness::Base(Value::known(public_x)),
54 Witness::Base(Value::known(public_y)),
55 Witness::Base(Value::known(pallas::Base::from(self.coin_attrs.value))),
56 Witness::Base(Value::known(self.coin_attrs.spend_hook.inner())),
57 Witness::Base(Value::known(self.coin_attrs.user_data)),
58 Witness::Base(Value::known(self.coin_attrs.blind.inner())),
59 Witness::Base(Value::known(self.token_attrs.auth_parent.inner())),
61 Witness::Base(Value::known(self.token_attrs.user_data)),
62 Witness::Base(Value::known(self.token_attrs.blind.inner())),
63 ];
64
65 let coin = self.coin_attrs.to_coin();
66
67 let public_inputs = vec![self.token_attrs.auth_parent.inner(), coin.inner()];
68
69 let circuit = ZkCircuit::new(prover_witnesses, &self.mint_zkbin);
71 let proof = Proof::create(&self.mint_pk, &[circuit], &public_inputs, &mut OsRng)?;
72
73 let params = MoneyTokenMintParamsV1 { coin };
74 let debris = TokenMintCallDebris { params, proofs: vec![proof] };
75 Ok(debris)
76 }
77}