diff --git a/ApolloBuilder.go b/ApolloBuilder.go index 022640b..6bc4bcc 100644 --- a/ApolloBuilder.go +++ b/ApolloBuilder.go @@ -340,7 +340,13 @@ func (b *Apollo) AddDatum(pd *PlutusData.PlutusData) *Apollo { Returns: *Apollo: A pointer to the modified Apollo instance with the payment and datum added. */ -func (b *Apollo) PayToContract(contractAddress Address.Address, pd *PlutusData.PlutusData, lovelace int, isInline bool, units ...Unit) *Apollo { +func (b *Apollo) PayToContract( + contractAddress Address.Address, + pd *PlutusData.PlutusData, + lovelace int, + isInline bool, + units ...Unit, +) *Apollo { if isInline { b = b.AddPayment(&Payment{lovelace, contractAddress, units, pd, nil, isInline}) } else if pd != nil { @@ -358,25 +364,40 @@ func (b *Apollo) PayToContract(contractAddress Address.Address, pd *PlutusData.P /* * - AddRequiredSignerFromBech32 decodes an address in Bech32 format and adds - its payment and staking parts as required signers. + AddRequiredSignerFromBech32 decodes an address in Bech32 format and adds + its payment and staking parts as required signers. + + Params: + + + address (string): The Bech32-encoded address to decode and add its parts as required signers. + + + addPaymentPart (bool): Indicates whether to add the payment part as a required signer. + - Params: - address (string): The Bech32-encoded address to decode and add its parts as required signers. - addPaymentPart (bool): Indicates whether to add the payment part as a required signer. addStakingPart (bool): Indicates whether to add the staking part as a required signer. Returns: *Apollo: A pointer to the modified Apollo instance with the required signers added. */ -func (b *Apollo) AddRequiredSignerFromBech32(address string, addPaymentPart, addStakingPart bool) *Apollo { +func (b *Apollo) AddRequiredSignerFromBech32( + address string, + addPaymentPart, addStakingPart bool, +) *Apollo { decoded_addr, _ := Address.DecodeAddress(address) if addPaymentPart { - b.requiredSigners = append(b.requiredSigners, serialization.PubKeyHash(decoded_addr.PaymentPart[0:28])) + b.requiredSigners = append( + b.requiredSigners, + serialization.PubKeyHash(decoded_addr.PaymentPart[0:28]), + ) } if addStakingPart { - b.requiredSigners = append(b.requiredSigners, serialization.PubKeyHash(decoded_addr.StakingPart[0:28])) + b.requiredSigners = append( + b.requiredSigners, + serialization.PubKeyHash(decoded_addr.StakingPart[0:28]), + ) } return b @@ -404,14 +425,23 @@ func (b *Apollo) AddRequiredSigner(pkh serialization.PubKeyHash) *Apollo { AddRequiredSignerFromAddress extracts the payment and staking parts from an address and adds them as required signers. Params: - address (Address.Address): The address from which to extract the parts and add them as required signers. - addPaymentPart (bool): Indicates whether to add the payment part as a required signer. - addStakingPart (bool): Indicates whether to add the staking part as a required signer. - Returns: - *Apollo: A pointer to the modified Apollo instance with the required signers added. + + address (Address.Address): The address from which to extract the parts and add them as required signers. + + + addPaymentPart (bool): Indicates whether to add the payment part as a required signer. + + + addStakingPart (bool): Indicates whether to add the staking part as a required signer. + + Returns: + *Apollo: A pointer to the modified Apollo instance with the required signers added. */ -func (b *Apollo) AddRequiredSignerFromAddress(address Address.Address, addPaymentPart, addStakingPart bool) *Apollo { +func (b *Apollo) AddRequiredSignerFromAddress( + address Address.Address, + addPaymentPart, addStakingPart bool, +) *Apollo { if addPaymentPart { pkh := serialization.PubKeyHash(address.PaymentPart) @@ -754,7 +784,13 @@ func (b *Apollo) estimateFee() (int64, error) { } fakeTxBytes, _ := fftx.Bytes() fakeTxLength := len([]byte(hex.EncodeToString(fakeTxBytes))) - estimatedFee, err := Utils.Fee(b.Context, fakeTxLength, pExU.Steps, pExU.Mem, fftx.TransactionBody.ReferenceInputs) + estimatedFee, err := Utils.Fee( + b.Context, + fakeTxLength, + pExU.Steps, + pExU.Mem, + fftx.TransactionBody.ReferenceInputs, + ) if err != nil { return 0, err } @@ -836,10 +872,14 @@ func (b *Apollo) setCollateral() (*Apollo, error) { if len(b.collaterals) > 0 { collateral_amount := 5_000_000 for _, utxo := range b.collaterals { - if int(utxo.Output.GetValue().GetCoin()) >= collateral_amount+1_000_000 && len(utxo.Output.GetValue().GetAssets()) <= 5 { + if int(utxo.Output.GetValue().GetCoin()) >= collateral_amount+1_000_000 && + len(utxo.Output.GetValue().GetAssets()) <= 5 { b.totalCollateral = collateral_amount return_amount := utxo.Output.GetValue().GetCoin() - int64(collateral_amount) - returnOutput := TransactionOutput.SimpleTransactionOutput(b.inputAddresses[0], Value.SimpleValue(return_amount, utxo.Output.GetValue().GetAssets())) + returnOutput := TransactionOutput.SimpleTransactionOutput( + b.inputAddresses[0], + Value.SimpleValue(return_amount, utxo.Output.GetValue().GetAssets()), + ) b.collateralReturn = &returnOutput } } @@ -854,9 +894,16 @@ func (b *Apollo) setCollateral() (*Apollo, error) { availableUtxos := b.getAvailableUtxos() collateral_amount := 5_000_000 for _, utxo := range availableUtxos { - if int(utxo.Output.GetValue().GetCoin()) >= collateral_amount && len(utxo.Output.GetValue().GetAssets()) <= 5 { + if int(utxo.Output.GetValue().GetCoin()) >= collateral_amount && + len(utxo.Output.GetValue().GetAssets()) <= 5 { return_amount := utxo.Output.GetValue().GetCoin() - int64(collateral_amount) - min_lovelace, err := Utils.MinLovelacePostAlonzo(TransactionOutput.SimpleTransactionOutput(b.inputAddresses[0], Value.SimpleValue(return_amount, utxo.Output.GetAmount().GetAssets())), b.Context) + min_lovelace, err := Utils.MinLovelacePostAlonzo( + TransactionOutput.SimpleTransactionOutput( + b.inputAddresses[0], + Value.SimpleValue(return_amount, utxo.Output.GetAmount().GetAssets()), + ), + b.Context, + ) if err != nil { return b, err } @@ -878,7 +925,13 @@ func (b *Apollo) setCollateral() (*Apollo, error) { for _, utxo := range availableUtxos { if int(utxo.Output.GetValue().GetCoin()) >= collateral_amount { return_amount := utxo.Output.GetValue().GetCoin() - int64(collateral_amount) - min_lovelace, err := Utils.MinLovelacePostAlonzo(TransactionOutput.SimpleTransactionOutput(b.inputAddresses[0], Value.SimpleValue(return_amount, utxo.Output.GetAmount().GetAssets())), b.Context) + min_lovelace, err := Utils.MinLovelacePostAlonzo( + TransactionOutput.SimpleTransactionOutput( + b.inputAddresses[0], + Value.SimpleValue(return_amount, utxo.Output.GetAmount().GetAssets()), + ), + b.Context, + ) if err != nil { return b, err } @@ -1100,7 +1153,11 @@ func (b *Apollo) Complete() (*Apollo, error) { } } for { - if selectedAmount.Greater(requestedAmount.Add(Value.Value{Am: Amount.Amount{}, Coin: 1_000_000, HasAssets: false})) { + if selectedAmount.Greater( + requestedAmount.Add( + Value.Value{Am: Amount.Amount{}, Coin: 1_000_000, HasAssets: false}, + ), + ) { break } if len(available_utxos) == 0 { @@ -1140,7 +1197,12 @@ func (b *Apollo) Complete() (*Apollo, error) { return nil, err } witnessSet := b.buildWitnessSet() - b.tx = &Transaction.Transaction{TransactionBody: body, TransactionWitnessSet: witnessSet, AuxiliaryData: b.auxiliaryData, Valid: true} + b.tx = &Transaction.Transaction{ + TransactionBody: body, + TransactionWitnessSet: witnessSet, + AuxiliaryData: b.auxiliaryData, + Valid: true, + } return b, nil } @@ -1158,8 +1220,15 @@ func (b *Apollo) Complete() (*Apollo, error) { Returns: bool: True if adding change would exceed the UTXO limit, false otherwise. */ -func isOverUtxoLimit(change Value.Value, address Address.Address, b Base.ChainContext) (bool, error) { - txOutput := TransactionOutput.SimpleTransactionOutput(address, Value.SimpleValue(0, change.GetAssets())) +func isOverUtxoLimit( + change Value.Value, + address Address.Address, + b Base.ChainContext, +) (bool, error) { + txOutput := TransactionOutput.SimpleTransactionOutput( + address, + Value.SimpleValue(0, change.GetAssets()), + ) encoded, _ := cbor.Marshal(txOutput) pps, err := b.GetProtocolParams() if err != nil { @@ -1182,7 +1251,9 @@ func isOverUtxoLimit(change Value.Value, address Address.Address, b Base.ChainCo b: The ChainContext providing protocol parameters. Returns: - []*Payment: An array of payment objects, split if necessary to avoid exceeding the UTxO limit. + + + []*Payment: An array of payment objects, split if necessary to avoid exceeding the UTxO limit. */ func splitPayments(c Value.Value, a Address.Address, b Base.ChainContext) ([]*Payment, error) { lovelace := c.GetCoin() @@ -1306,7 +1377,10 @@ func (b *Apollo) addChangeAndFee() (*Apollo, error) { requestedAmount.AddLovelace(b.Fee) change := providedAmount.Sub(requestedAmount) minLovelaceRequired, err := Utils.MinLovelacePostAlonzo( - TransactionOutput.SimpleTransactionOutput(b.inputAddresses[0], Value.SimpleValue(0, change.GetAssets())), + TransactionOutput.SimpleTransactionOutput( + b.inputAddresses[0], + Value.SimpleValue(0, change.GetAssets()), + ), b.Context, ) if err != nil { @@ -1466,7 +1540,10 @@ Returns: error: an error if setWalletFromMnemonic fails. */ -func (a *Apollo) SetWalletFromMnemonic(mnemonic string, network constants.Network) (*Apollo, error) { +func (a *Apollo) SetWalletFromMnemonic( + mnemonic string, + network constants.Network, +) (*Apollo, error) { paymentPath := "m/1852'/1815'/0'/0/0" stakingPath := "m/1852'/1815'/0'/2/0" hdWall, err := HDWallet.NewHDWalletFromMnemonic(mnemonic, "") @@ -1488,19 +1565,32 @@ func (a *Apollo) SetWalletFromMnemonic(mnemonic string, network constants.Networ //stake := stakingKeyPath.RootXprivKey.Bytes() signingKey := Key.SigningKey{Payload: signingKey_bytes} verificationKey := Key.VerificationKey{Payload: verificationKey_bytes} - stakeSigningKey := Key.StakeSigningKey{Payload: stakeSigningKey_bytes} - stakeVerificationKey := Key.StakeVerificationKey{Payload: stakeVerificationKey_bytes} + stakeSigningKey := Key.SigningKey{Payload: stakeSigningKey_bytes} + stakeVerificationKey := Key.VerificationKey{Payload: stakeVerificationKey_bytes} stakeVerKey := Key.VerificationKey{Payload: stakeVerificationKey_bytes} skh, _ := stakeVerKey.Hash() vkh, _ := verificationKey.Hash() addr := Address.Address{} if network == constants.MAINNET { - addr = Address.Address{StakingPart: skh[:], PaymentPart: vkh[:], Network: 1, AddressType: Address.KEY_KEY, HeaderByte: 0b00000001, Hrp: "addr"} + addr = Address.Address{ + StakingPart: skh[:], + PaymentPart: vkh[:], + Network: 1, + AddressType: Address.KEY_KEY, + HeaderByte: 0b00000001, + Hrp: "addr", + } } else { addr = Address.Address{StakingPart: skh[:], PaymentPart: vkh[:], Network: 0, AddressType: Address.KEY_KEY, HeaderByte: 0b00000000, Hrp: "addr_test"} } - wallet := apollotypes.GenericWallet{SigningKey: signingKey, VerificationKey: verificationKey, Address: addr, StakeSigningKey: stakeSigningKey, StakeVerificationKey: stakeVerificationKey} + wallet := apollotypes.GenericWallet{ + SigningKey: signingKey, + VerificationKey: verificationKey, + Address: addr, + StakeSigningKey: stakeSigningKey, + StakeVerificationKey: stakeVerificationKey, + } a.wallet = &wallet return a, nil } @@ -1525,7 +1615,14 @@ func (a *Apollo) SetWalletFromKeypair(vkey string, skey string, network constant addr := Address.Address{} if network == constants.MAINNET { - addr = Address.Address{StakingPart: nil, PaymentPart: vkh[:], Network: 1, AddressType: Address.KEY_NONE, HeaderByte: 0b01100001, Hrp: "addr"} + addr = Address.Address{ + StakingPart: nil, + PaymentPart: vkh[:], + Network: 1, + AddressType: Address.KEY_NONE, + HeaderByte: 0b01100001, + Hrp: "addr", + } } else { addr = Address.Address{StakingPart: nil, PaymentPart: vkh[:], Network: 0, AddressType: Address.KEY_NONE, HeaderByte: 0b01100000, Hrp: "addr_test"} } @@ -1533,8 +1630,8 @@ func (a *Apollo) SetWalletFromKeypair(vkey string, skey string, network constant SigningKey: signingKey, VerificationKey: verificationKey, Address: addr, - StakeSigningKey: Key.StakeSigningKey{}, - StakeVerificationKey: Key.StakeVerificationKey{}, + StakeSigningKey: Key.SigningKey{}, + StakeVerificationKey: Key.VerificationKey{}, } a.wallet = &wallet return a @@ -1613,7 +1710,10 @@ func (b *Apollo) SignWithSkey(vkey Key.VerificationKey, skey Key.SigningKey) (*A if err != nil { return b, err } - witness_set.VkeyWitnesses = append(witness_set.VkeyWitnesses, VerificationKeyWitness.VerificationKeyWitness{Vkey: vkey, Signature: signature}) + witness_set.VkeyWitnesses = append( + witness_set.VkeyWitnesses, + VerificationKeyWitness.VerificationKeyWitness{Vkey: vkey, Signature: signature}, + ) b.GetTx().TransactionWitnessSet = witness_set return b, nil } @@ -1694,7 +1794,9 @@ func (b *Apollo) UtxoFromRef(txHash string, txIndex int) (*UTxO.UTxO, error) { Returns: *Apollo: A pointer to the modified Apollo instance with the added verification key witness. */ -func (b *Apollo) AddVerificationKeyWitness(vkw VerificationKeyWitness.VerificationKeyWitness) *Apollo { +func (b *Apollo) AddVerificationKeyWitness( + vkw VerificationKeyWitness.VerificationKeyWitness, +) *Apollo { b.tx.TransactionWitnessSet.VkeyWitnesses = append(b.tx.TransactionWitnessSet.VkeyWitnesses, vkw) return b } @@ -1804,11 +1906,13 @@ func (b *Apollo) GetUsedUTxOs() []string { /* * - SetEstimationExUnitsRequired enables the estimation of execution units - for the transaction. + SetEstimationExUnitsRequired enables the estimation of execution units + for the transaction. - Returns: - *Apollo: A pointer to the modified Apollo instance with execution units estimation enabled. + Returns: + + + *Apollo: A pointer to the modified Apollo instance with execution units estimation enabled. */ func (b *Apollo) SetEstimationExUnitsRequired() *Apollo { b.isEstimateRequired = true @@ -1854,14 +1958,20 @@ func (b *Apollo) AddReferenceInput(txHash string, index int) *Apollo { DisableExecutionUnitsEstimation disables the estimation of execution units for the transaction. Returns: - *Apollo: A pointer to the modified Apollo instance with execution units estimation disabled. + + + *Apollo: A pointer to the modified Apollo instance with execution units estimation disabled. */ func (b *Apollo) DisableExecutionUnitsEstimation() *Apollo { b.isEstimateRequired = false return b } -func (b *Apollo) AddWithdrawal(address Address.Address, amount int, redeemerData PlutusData.PlutusData) *Apollo { +func (b *Apollo) AddWithdrawal( + address Address.Address, + amount int, + redeemerData PlutusData.PlutusData, +) *Apollo { if b.withdrawals == nil { newWithdrawal := Withdrawal.New() b.withdrawals = &newWithdrawal @@ -1869,7 +1979,10 @@ func (b *Apollo) AddWithdrawal(address Address.Address, amount int, redeemerData var stakeAddr [29]byte stakeAddr[0] = address.HeaderByte if len(address.StakingPart) != 28 { - fmt.Printf("AddWithdrawal: address has invalid or missing staking part: %v\n", address.StakingPart) + fmt.Printf( + "AddWithdrawal: address has invalid or missing staking part: %v\n", + address.StakingPart, + ) } copy(stakeAddr[1:], address.StakingPart) err := b.withdrawals.Add(stakeAddr, amount) @@ -1913,7 +2026,12 @@ func (b *Apollo) CompleteExact(fee int) (*Apollo, error) { return nil, err } witnessSet := b.buildWitnessSet() - b.tx = &Transaction.Transaction{TransactionBody: body, TransactionWitnessSet: witnessSet, AuxiliaryData: b.auxiliaryData, Valid: true} + b.tx = &Transaction.Transaction{ + TransactionBody: body, + TransactionWitnessSet: witnessSet, + AuxiliaryData: b.auxiliaryData, + Valid: true, + } return b, nil } diff --git a/ApolloBuilder_test.go b/ApolloBuilder_test.go index 1e19f75..82630bc 100644 --- a/ApolloBuilder_test.go +++ b/ApolloBuilder_test.go @@ -93,7 +93,11 @@ func TestEnsureTxIsBalanced(t *testing.T) { inputVal := Value.SimpleValue(0, MultiAsset.MultiAsset[int64]{}) for _, input := range apollob.GetTx().TransactionBody.Inputs { for _, utxo := range utxos { - if utxo.GetKey() == fmt.Sprintf("%s:%d", hex.EncodeToString(input.TransactionId), input.Index) { + if utxo.GetKey() == fmt.Sprintf( + "%s:%d", + hex.EncodeToString(input.TransactionId), + input.Index, + ) { //fmt.Println("INPUT", idx, utxo) inputVal = inputVal.Add(utxo.Output.GetAmount()) } @@ -143,12 +147,15 @@ func TestComplexTxBuild(t *testing.T) { } utxos = append(utxos, loadedUtxo) } - decodedAddress, _ := Address.DecodeAddress("addr1wxr2a8htmzuhj39y2gq7ftkpxv98y2g67tg8zezthgq4jkg0a4ul4") + decodedAddress, _ := Address.DecodeAddress( + "addr1wxr2a8htmzuhj39y2gq7ftkpxv98y2g67tg8zezthgq4jkg0a4ul4", + ) apollob = apollob.AddInputAddressFromBech32(userAddress).AddLoadedUTxOs(utxos...). PayToContract(decodedAddress, &pd, 4000000, false, - apollo.NewUnit("279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3f", "SNEK", 10416)). + apollo.NewUnit("279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3f", "SNEK", 10416), + ). PayToAddressBech32("addr1qxajla3qcrwckzkur8n0lt02rg2sepw3kgkstckmzrz4ccfm3j9pqrqkea3tns46e3qy2w42vl8dvvue8u45amzm3rjqvv2nxh", int(2_000_000)). SetTtl(0 + 300). SetValidityStart(0) @@ -161,7 +168,11 @@ func TestComplexTxBuild(t *testing.T) { inputVal := Value.SimpleValue(0, MultiAsset.MultiAsset[int64]{}) for _, input := range apollob.GetTx().TransactionBody.Inputs { for _, utxo := range utxos { - if utxo.GetKey() == fmt.Sprintf("%s:%d", hex.EncodeToString(input.TransactionId), input.Index) { + if utxo.GetKey() == fmt.Sprintf( + "%s:%d", + hex.EncodeToString(input.TransactionId), + input.Index, + ) { //fmt.Println("INPUT", idx, utxo) inputVal = inputVal.Add(utxo.Output.GetAmount()) } @@ -216,12 +227,15 @@ func TestFakeBurnBalancing(t *testing.T) { } utxos = append(utxos, loadedUtxo) } - decodedAddress, _ := Address.DecodeAddress("addr1wxr2a8htmzuhj39y2gq7ftkpxv98y2g67tg8zezthgq4jkg0a4ul4") + decodedAddress, _ := Address.DecodeAddress( + "addr1wxr2a8htmzuhj39y2gq7ftkpxv98y2g67tg8zezthgq4jkg0a4ul4", + ) apollob = apollob.AddInputAddressFromBech32(userAddress).AddLoadedUTxOs(utxos...). PayToContract(decodedAddress, &pd, 4000000, false, - apollo.NewUnit("279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3f", "SNEK", 10416)). + apollo.NewUnit("279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3f", "SNEK", 10416), + ). PayToAddressBech32("addr1qxajla3qcrwckzkur8n0lt02rg2sepw3kgkstckmzrz4ccfm3j9pqrqkea3tns46e3qy2w42vl8dvvue8u45amzm3rjqvv2nxh", int(2_000_000)). SetTtl(0 + 300). SetValidityStart(0).MintAssets( @@ -238,7 +252,11 @@ func TestFakeBurnBalancing(t *testing.T) { inputVal := Value.SimpleValue(0, MultiAsset.MultiAsset[int64]{}) for _, input := range apollob.GetTx().TransactionBody.Inputs { for _, utxo := range utxos { - if utxo.GetKey() == fmt.Sprintf("%s:%d", hex.EncodeToString(input.TransactionId), input.Index) { + if utxo.GetKey() == fmt.Sprintf( + "%s:%d", + hex.EncodeToString(input.TransactionId), + input.Index, + ) { //fmt.Println("INPUT", idx, utxo) inputVal = inputVal.Add(utxo.Output.GetAmount()) } @@ -272,8 +290,15 @@ func TestScriptAddress(t *testing.T) { } p2Script := PlutusData.PlutusV2Script(decoded_string) hashOfScript, _ := p2Script.Hash() - if hex.EncodeToString(hashOfScript.Bytes()) != "f3f821d122b041244de074b9554c7dbcc62f34f62426344c0d0b4c86" { - t.Error("Hash of script is not correct", hex.EncodeToString(hashOfScript.Bytes()), " != ", "f3f821d122b041244de074b9554c7dbcc62f34f62426344c0d0b4c86") + if hex.EncodeToString( + hashOfScript.Bytes(), + ) != "f3f821d122b041244de074b9554c7dbcc62f34f62426344c0d0b4c86" { + t.Error( + "Hash of script is not correct", + hex.EncodeToString(hashOfScript.Bytes()), + " != ", + "f3f821d122b041244de074b9554c7dbcc62f34f62426344c0d0b4c86", + ) } } @@ -437,7 +462,11 @@ func TestScriptAddress(t *testing.T) { // } func TestFailedSubmissionThrows(t *testing.T) { - cc, err := BlockFrostChainContext.NewBlockfrostChainContext(BLOCKFROST_BASE_URL_MAINNET, int(MAINNET), "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT") + cc, err := BlockFrostChainContext.NewBlockfrostChainContext( + BLOCKFROST_BASE_URL_MAINNET, + int(MAINNET), + "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT", + ) if err != nil { t.Error(err) } @@ -457,17 +486,25 @@ func TestFailedSubmissionThrows(t *testing.T) { } func TestBurnPlutus(t *testing.T) { - cc, err := BlockFrostChainContext.NewBlockfrostChainContext(BLOCKFROST_BASE_URL_MAINNET, int(MAINNET), "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT") + cc, err := BlockFrostChainContext.NewBlockfrostChainContext( + BLOCKFROST_BASE_URL_MAINNET, + int(MAINNET), + "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT", + ) if err != nil { t.Error(err) } - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) policy := Policy.PolicyId{Value: "279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3f"} testUtxo := UTxO.UTxO{ Input: TransactionInput.TransactionInput{ - TransactionId: []byte("d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056"), - Index: 0, + TransactionId: []byte( + "d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056", + ), + Index: 0, }, Output: TransactionOutput.SimpleTransactionOutput( decoded_addr, @@ -493,22 +530,32 @@ func TestBurnPlutus(t *testing.T) { t.Error(err) } txBytes, err := apollob.GetTx().Bytes() - if hex.EncodeToString(txBytes) != "84a5008182584064356431663763323233646338386262343134373461663233623638356530323437333037653934653731356566356536326633323561633934663733303536000181825839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c91a00e1eefb021a0002f2c509a1581c279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3fa14454455354200b58207c2fde0c1908393e41c7b4afbfee2686378e714d70fc335b6cd0142ac6de9772a10581840000f6820000f5f6" { + if hex.EncodeToString( + txBytes, + ) != "84a5008182584064356431663763323233646338386262343134373461663233623638356530323437333037653934653731356566356536326633323561633934663733303536000181825839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c91a00e1eefb021a0002f2c509a1581c279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3fa14454455354200b58207c2fde0c1908393e41c7b4afbfee2686378e714d70fc335b6cd0142ac6de9772a10581840000f6820000f5f6" { t.Error("Tx is not correct", hex.EncodeToString(txBytes)) } } func TestMintPlutus(t *testing.T) { - cc, err := BlockFrostChainContext.NewBlockfrostChainContext(BLOCKFROST_BASE_URL_MAINNET, int(MAINNET), "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT") + cc, err := BlockFrostChainContext.NewBlockfrostChainContext( + BLOCKFROST_BASE_URL_MAINNET, + int(MAINNET), + "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT", + ) if err != nil { t.Error(err) } - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) policy := Policy.PolicyId{Value: "279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3f"} testUtxo := UTxO.UTxO{ Input: TransactionInput.TransactionInput{ - TransactionId: []byte("d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056"), - Index: 0, + TransactionId: []byte( + "d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056", + ), + Index: 0, }, Output: TransactionOutput.SimpleTransactionOutput( decoded_addr, @@ -532,22 +579,32 @@ func TestMintPlutus(t *testing.T) { t.Error(err) } txBytes, err := apollob.GetTx().Bytes() - if hex.EncodeToString(txBytes) != "84a5008182584064356431663763323233646338386262343134373461663233623638356530323437333037653934653731356566356536326633323561633934663733303536000181825839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c9821a00e1e193a1581c279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3fa1445445535401021a0003002d09a1581c279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3fa14454455354010b58207c2fde0c1908393e41c7b4afbfee2686378e714d70fc335b6cd0142ac6de9772a10581840000f6820000f5f6" { + if hex.EncodeToString( + txBytes, + ) != "84a5008182584064356431663763323233646338386262343134373461663233623638356530323437333037653934653731356566356536326633323561633934663733303536000181825839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c9821a00e1e193a1581c279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3fa1445445535401021a0003002d09a1581c279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3fa14454455354010b58207c2fde0c1908393e41c7b4afbfee2686378e714d70fc335b6cd0142ac6de9772a10581840000f6820000f5f6" { t.Error("Tx is not correct", hex.EncodeToString(txBytes)) } } func TestMintPlutusWithPayment(t *testing.T) { - cc, err := BlockFrostChainContext.NewBlockfrostChainContext(BLOCKFROST_BASE_URL_MAINNET, int(MAINNET), "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT") + cc, err := BlockFrostChainContext.NewBlockfrostChainContext( + BLOCKFROST_BASE_URL_MAINNET, + int(MAINNET), + "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT", + ) if err != nil { t.Error(err) } - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) policy := Policy.PolicyId{Value: "279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3f"} testUtxo := UTxO.UTxO{ Input: TransactionInput.TransactionInput{ - TransactionId: []byte("d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056"), - Index: 0, + TransactionId: []byte( + "d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056", + ), + Index: 0, }, Output: TransactionOutput.SimpleTransactionOutput( decoded_addr, @@ -578,13 +635,19 @@ func TestMintPlutusWithPayment(t *testing.T) { t.Error(err) } txBytes, err := apollob.GetTx().Bytes() - if hex.EncodeToString(txBytes) != "84a5008182584064356431663763323233646338386262343134373461663233623638356530323437333037653934653731356566356536326633323561633934663733303536000182825839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c9821a001484d0a1581c279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3fa1445445535401825839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c91a00cd466b021a0003168509a1581c279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3fa14454455354010b58207c2fde0c1908393e41c7b4afbfee2686378e714d70fc335b6cd0142ac6de9772a10581840000f6820000f5f6" { + if hex.EncodeToString( + txBytes, + ) != "84a5008182584064356431663763323233646338386262343134373461663233623638356530323437333037653934653731356566356536326633323561633934663733303536000182825839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c9821a001484d0a1581c279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3fa1445445535401825839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c91a00cd466b021a0003168509a1581c279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3fa14454455354010b58207c2fde0c1908393e41c7b4afbfee2686378e714d70fc335b6cd0142ac6de9772a10581840000f6820000f5f6" { t.Error("Tx is not correct", hex.EncodeToString(txBytes)) } } func TestGetWallet(t *testing.T) { - cc, err := BlockFrostChainContext.NewBlockfrostChainContext(BLOCKFROST_BASE_URL_MAINNET, int(MAINNET), "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT") + cc, err := BlockFrostChainContext.NewBlockfrostChainContext( + BLOCKFROST_BASE_URL_MAINNET, + int(MAINNET), + "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT", + ) if err != nil { t.Error(err) } @@ -593,23 +656,35 @@ func TestGetWallet(t *testing.T) { if wall != nil { t.Error("Wallet should be nil") } - apollob = apollob.SetWalletFromBech32("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + apollob = apollob.SetWalletFromBech32( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) wallet := apollob.GetWallet() - if wallet.GetAddress().String() != "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu" { + if wallet.GetAddress(). + String() != + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu" { t.Error("Wallet address is not correct") } } func TestAddInputs(t *testing.T) { - cc, err := BlockFrostChainContext.NewBlockfrostChainContext(BLOCKFROST_BASE_URL_MAINNET, int(MAINNET), "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT") + cc, err := BlockFrostChainContext.NewBlockfrostChainContext( + BLOCKFROST_BASE_URL_MAINNET, + int(MAINNET), + "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT", + ) if err != nil { t.Error(err) } - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) testUtxo := UTxO.UTxO{ Input: TransactionInput.TransactionInput{ - TransactionId: []byte("d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056"), - Index: 0, + TransactionId: []byte( + "d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056", + ), + Index: 0, }, Output: TransactionOutput.SimpleTransactionOutput( decoded_addr, @@ -628,15 +703,23 @@ func TestAddInputs(t *testing.T) { } func TestConsumeUtxo(t *testing.T) { - cc, err := BlockFrostChainContext.NewBlockfrostChainContext(BLOCKFROST_BASE_URL_MAINNET, int(MAINNET), "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT") + cc, err := BlockFrostChainContext.NewBlockfrostChainContext( + BLOCKFROST_BASE_URL_MAINNET, + int(MAINNET), + "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT", + ) if err != nil { t.Error(err) } - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) testUtxo := UTxO.UTxO{ Input: TransactionInput.TransactionInput{ - TransactionId: []byte("d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056"), - Index: 0, + TransactionId: []byte( + "d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056", + ), + Index: 0, }, Output: TransactionOutput.SimpleTransactionOutput( decoded_addr, @@ -644,8 +727,10 @@ func TestConsumeUtxo(t *testing.T) { } biAdaUtxo := UTxO.UTxO{ Input: TransactionInput.TransactionInput{ - TransactionId: []byte("d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056"), - Index: 1, + TransactionId: []byte( + "d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056", + ), + Index: 1, }, Output: TransactionOutput.SimpleTransactionOutput( decoded_addr, @@ -656,7 +741,9 @@ func TestConsumeUtxo(t *testing.T) { apollob = apollob.SetChangeAddress(decoded_addr). ConsumeUTxO(testUtxo, apollo.NewPayment("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", 2_000_000, nil), - apollo.NewPayment("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", 2_000_000, nil)).AddLoadedUTxOs(biAdaUtxo) + apollo.NewPayment("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", 2_000_000, nil), + ). + AddLoadedUTxOs(biAdaUtxo) built, err := apollob.Complete() if err != nil { t.Error(err) @@ -680,15 +767,23 @@ func TestConsumeUtxo(t *testing.T) { func TestConsumeAssetsFromUtxo(t *testing.T) { - cc, err := BlockFrostChainContext.NewBlockfrostChainContext(BLOCKFROST_BASE_URL_MAINNET, int(MAINNET), "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT") + cc, err := BlockFrostChainContext.NewBlockfrostChainContext( + BLOCKFROST_BASE_URL_MAINNET, + int(MAINNET), + "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT", + ) if err != nil { t.Error(err) } - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) testUtxo := UTxO.UTxO{ Input: TransactionInput.TransactionInput{ - TransactionId: []byte("d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056"), - Index: 0, + TransactionId: []byte( + "d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056", + ), + Index: 0, }, Output: TransactionOutput.SimpleTransactionOutput( decoded_addr, @@ -700,8 +795,10 @@ func TestConsumeAssetsFromUtxo(t *testing.T) { } biAdaUtxo := UTxO.UTxO{ Input: TransactionInput.TransactionInput{ - TransactionId: []byte("d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056"), - Index: 1, + TransactionId: []byte( + "d5d1f7c223dc88bb41474af23b685e0247307e94e715ef5e62f325ac94f73056", + ), + Index: 1, }, Output: TransactionOutput.SimpleTransactionOutput( decoded_addr, @@ -711,7 +808,9 @@ func TestConsumeAssetsFromUtxo(t *testing.T) { apollob := apollo.New(&cc) apollob = apollob.SetChangeAddress(decoded_addr). ConsumeAssetsFromUtxo(testUtxo, - apollo.NewPayment("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", 2_000_000, []apollo.Unit{apollo.NewUnit("279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3f", "TEST", 1)})).AddLoadedUTxOs(biAdaUtxo) + apollo.NewPayment("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", 2_000_000, []apollo.Unit{apollo.NewUnit("279c909f348e533da5808898f87f9a14bb2c3dfbbacccd631d927a3f", "TEST", 1)}), + ). + AddLoadedUTxOs(biAdaUtxo) built, err := apollob.Complete() if err != nil { t.Error(err) @@ -734,7 +833,9 @@ func TestConsumeAssetsFromUtxo(t *testing.T) { } } -var decoded_addr, _ = Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") +var decoded_addr, _ = Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", +) var InputUtxo = UTxO.UTxO{ Input: TransactionInput.TransactionInput{ @@ -747,11 +848,17 @@ var InputUtxo = UTxO.UTxO{ } func TestPayToContract(t *testing.T) { - cc, err := BlockFrostChainContext.NewBlockfrostChainContext(BLOCKFROST_BASE_URL_MAINNET, int(MAINNET), "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT") + cc, err := BlockFrostChainContext.NewBlockfrostChainContext( + BLOCKFROST_BASE_URL_MAINNET, + int(MAINNET), + "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT", + ) if err != nil { t.Error(err) } - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) datum := PlutusData.PlutusData{ TagNr: 121, PlutusDataType: PlutusData.PlutusBytes, @@ -799,18 +906,26 @@ func TestPayToContract(t *testing.T) { t.Error("Tx is not correct", built.GetTx().TransactionBody.Outputs[1].GetDatum().TagNr) } txBytes, _ := built.GetTx().Bytes() - if hex.EncodeToString(txBytes) != "84a4008182584064356431663763323233646338386262343134373461663233623638356530323437333037653934653731356566356536326633323561633934663733303536010183835839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c91a000f4240582037ead362f4ab7844a8416b045caa46a91066d391c16ae4d4a81557f14f7a0984a3005839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c9011a000f4240028201d81850d8794d48656c6c6f2c20576f726c6421825839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c91a00c333d3021a0003296d0b5820a1f321beb89d87d81b931988fc9561df62357c5b845ff48fdb926265a43110e2a1049fd8794d48656c6c6f2c20576f726c6421fff5f6" { + if hex.EncodeToString( + txBytes, + ) != "84a4008182584064356431663763323233646338386262343134373461663233623638356530323437333037653934653731356566356536326633323561633934663733303536010183835839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c91a000f4240582037ead362f4ab7844a8416b045caa46a91066d391c16ae4d4a81557f14f7a0984a3005839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c9011a000f4240028201d81850d8794d48656c6c6f2c20576f726c6421825839010a59337f7b3a913424d7f7a151401e052642b68e948d8cacadc6372016a9999419cc5a61ca62da81e378d7538213a3715a6b858c948c69c91a00c333d3021a0003296d0b5820a1f321beb89d87d81b931988fc9561df62357c5b845ff48fdb926265a43110e2a1049fd8794d48656c6c6f2c20576f726c6421fff5f6" { t.Error("Tx is not correct", hex.EncodeToString(txBytes)) } } func TestRequiredSigner(t *testing.T) { - cc, err := BlockFrostChainContext.NewBlockfrostChainContext(BLOCKFROST_BASE_URL_MAINNET, int(MAINNET), "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT") + cc, err := BlockFrostChainContext.NewBlockfrostChainContext( + BLOCKFROST_BASE_URL_MAINNET, + int(MAINNET), + "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT", + ) if err != nil { t.Error(err) } - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) apollob := apollo.New(&cc) apollob = apollob.SetChangeAddress(decoded_addr).AddLoadedUTxOs(InputUtxo). AddRequiredSignerFromAddress(decoded_addr, true, true) @@ -821,10 +936,18 @@ func TestRequiredSigner(t *testing.T) { if len(built.GetTx().TransactionBody.RequiredSigners) != 2 { t.Error("Tx is not correct") } - if hex.EncodeToString(built.GetTx().TransactionBody.RequiredSigners[0][:]) != hex.EncodeToString(decoded_addr.PaymentPart) { + if hex.EncodeToString( + built.GetTx().TransactionBody.RequiredSigners[0][:], + ) != hex.EncodeToString( + decoded_addr.PaymentPart, + ) { t.Error("Tx is not correct") } - if hex.EncodeToString(built.GetTx().TransactionBody.RequiredSigners[1][:]) != hex.EncodeToString(decoded_addr.StakingPart) { + if hex.EncodeToString( + built.GetTx().TransactionBody.RequiredSigners[1][:], + ) != hex.EncodeToString( + decoded_addr.StakingPart, + ) { t.Error("Tx is not correct") } apollob = apollo.New(&cc) @@ -837,10 +960,18 @@ func TestRequiredSigner(t *testing.T) { if len(built.GetTx().TransactionBody.RequiredSigners) != 2 { t.Error("Tx is not correct") } - if hex.EncodeToString(built.GetTx().TransactionBody.RequiredSigners[0][:]) != hex.EncodeToString(decoded_addr.PaymentPart) { + if hex.EncodeToString( + built.GetTx().TransactionBody.RequiredSigners[0][:], + ) != hex.EncodeToString( + decoded_addr.PaymentPart, + ) { t.Error("Tx is not correct") } - if hex.EncodeToString(built.GetTx().TransactionBody.RequiredSigners[1][:]) != hex.EncodeToString(decoded_addr.StakingPart) { + if hex.EncodeToString( + built.GetTx().TransactionBody.RequiredSigners[1][:], + ) != hex.EncodeToString( + decoded_addr.StakingPart, + ) { t.Error("Tx is not correct") } @@ -854,7 +985,11 @@ func TestRequiredSigner(t *testing.T) { if len(built.GetTx().TransactionBody.RequiredSigners) != 1 { t.Error("Tx is not correct") } - if hex.EncodeToString(built.GetTx().TransactionBody.RequiredSigners[0][:]) != hex.EncodeToString(decoded_addr.PaymentPart) { + if hex.EncodeToString( + built.GetTx().TransactionBody.RequiredSigners[0][:], + ) != hex.EncodeToString( + decoded_addr.PaymentPart, + ) { t.Error("Tx is not correct") } } @@ -878,13 +1013,22 @@ var collateralUtxo2 = UTxO.UTxO{ Value.SimpleValue(10_000_000, nil))} func TestFeePadding(t *testing.T) { - cc, err := BlockFrostChainContext.NewBlockfrostChainContext(BLOCKFROST_BASE_URL_MAINNET, int(MAINNET), "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT") + cc, err := BlockFrostChainContext.NewBlockfrostChainContext( + BLOCKFROST_BASE_URL_MAINNET, + int(MAINNET), + "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT", + ) if err != nil { t.Error(err) } - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) apollob := apollo.New(&cc) - apollob = apollob.SetChangeAddress(decoded_addr).AddLoadedUTxOs(InputUtxo).PayToContract(decoded_addr, nil, 1_000_000, false).SetFeePadding(500_000) + apollob = apollob.SetChangeAddress(decoded_addr). + AddLoadedUTxOs(InputUtxo). + PayToContract(decoded_addr, nil, 1_000_000, false). + SetFeePadding(500_000) built, err := apollob.Complete() if err != nil { t.Error(err) @@ -898,20 +1042,35 @@ func TestFeePadding(t *testing.T) { if built.GetTx().TransactionBody.Outputs[1].Lovelace() != 13308363 { t.Error("Tx is not correct", built.GetTx().TransactionBody.Outputs[1].Lovelace()) } - if built.GetTx().TransactionBody.Outputs[0].IsPostAlonzo && built.GetTx().TransactionBody.Outputs[0].GetDatumHash() != nil { - t.Error("Tx is not correct", built.GetTx().TransactionBody.Outputs[0].GetDatumHash(), built.GetTx().TransactionBody.Outputs[0].IsPostAlonzo) + if built.GetTx().TransactionBody.Outputs[0].IsPostAlonzo && + built.GetTx().TransactionBody.Outputs[0].GetDatumHash() != nil { + t.Error( + "Tx is not correct", + built.GetTx().TransactionBody.Outputs[0].GetDatumHash(), + built.GetTx().TransactionBody.Outputs[0].IsPostAlonzo, + ) } } func TestSetCollateral(t *testing.T) { // full 5 ada collateral - cc, err := BlockFrostChainContext.NewBlockfrostChainContext(BLOCKFROST_BASE_URL_MAINNET, int(MAINNET), "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT") + cc, err := BlockFrostChainContext.NewBlockfrostChainContext( + BLOCKFROST_BASE_URL_MAINNET, + int(MAINNET), + "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT", + ) if err != nil { t.Error(err) } - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) apollob := apollo.New(&cc) - apollob = apollob.SetChangeAddress(decoded_addr).AddLoadedUTxOs(InputUtxo).PayToContract(decoded_addr, nil, 1_000_000, false).SetFeePadding(500_000).AddCollateral(collateralUtxo) + apollob = apollob.SetChangeAddress(decoded_addr). + AddLoadedUTxOs(InputUtxo). + PayToContract(decoded_addr, nil, 1_000_000, false). + SetFeePadding(500_000). + AddCollateral(collateralUtxo) built, err := apollob.Complete() if err != nil { t.Error(err) @@ -923,13 +1082,23 @@ func TestSetCollateral(t *testing.T) { func TestCollateralwithReturn(t *testing.T) { // full 5 ada collateral - cc, err := BlockFrostChainContext.NewBlockfrostChainContext(BLOCKFROST_BASE_URL_MAINNET, int(MAINNET), "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT") + cc, err := BlockFrostChainContext.NewBlockfrostChainContext( + BLOCKFROST_BASE_URL_MAINNET, + int(MAINNET), + "mainnetVueasSgKfYhM4PQBq0UGipAyHBpbX4oT", + ) if err != nil { t.Error(err) } - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) apollob := apollo.New(&cc) - apollob = apollob.SetChangeAddress(decoded_addr).AddLoadedUTxOs(InputUtxo).PayToContract(decoded_addr, nil, 1_000_000, false).SetFeePadding(500_000).AddCollateral(collateralUtxo2) + apollob = apollob.SetChangeAddress(decoded_addr). + AddLoadedUTxOs(InputUtxo). + PayToContract(decoded_addr, nil, 1_000_000, false). + SetFeePadding(500_000). + AddCollateral(collateralUtxo2) built, err := apollob.Complete() if err != nil { t.Error(err) @@ -947,7 +1116,9 @@ func TestCollateralwithReturn(t *testing.T) { func TestRedeemerCollect(t *testing.T) { cc := apollo.NewEmptyBackend() - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) apollob := apollo.New(&cc) redeemer := Redeemer.Redeemer{ Tag: Redeemer.SPEND, @@ -964,7 +1135,8 @@ func TestRedeemerCollect(t *testing.T) { utxos := testutils.InitUtxosDifferentiated() apollob = apollob.SetChangeAddress(decoded_addr).AddLoadedUTxOs(utxos...). - CollectFrom(InputUtxo, redeemer).AttachDatum(&datum).AttachV1Script([]byte("Hello, World!")).SetEstimationExUnitsRequired() + CollectFrom(InputUtxo, redeemer). + AttachDatum(&datum).AttachV1Script([]byte("Hello, World!")).SetEstimationExUnitsRequired() built, err := apollob.Complete() if err != nil { t.Error(err) @@ -1023,9 +1195,12 @@ func TestRedeemerCollect(t *testing.T) { func TestAddSameScriptTwiceV1(t *testing.T) { cc := apollo.NewEmptyBackend() utxos := testutils.InitUtxosDifferentiated() - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) apollob := apollo.New(&cc) - apollob = apollob.AttachV1Script([]byte("Hello, World!")).AttachV1Script([]byte("Hello, World!")) + apollob = apollob.AttachV1Script([]byte("Hello, World!")). + AttachV1Script([]byte("Hello, World!")) apollob = apollob.SetChangeAddress(decoded_addr).AddLoadedUTxOs(utxos...) built, err := apollob.Complete() if err != nil { @@ -1040,9 +1215,12 @@ func TestAddSameScriptTwiceV1(t *testing.T) { func TestAddSameScriptTwiceV2(t *testing.T) { cc := apollo.NewEmptyBackend() utxos := testutils.InitUtxosDifferentiated() - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) apollob := apollo.New(&cc) - apollob = apollob.AttachV2Script([]byte("Hello, World!")).AttachV2Script([]byte("Hello, World!")) + apollob = apollob.AttachV2Script([]byte("Hello, World!")). + AttachV2Script([]byte("Hello, World!")) apollob = apollob.SetChangeAddress(decoded_addr).AddLoadedUTxOs(utxos...) built, err := apollob.Complete() if err != nil { @@ -1056,12 +1234,15 @@ func TestAddSameScriptTwiceV2(t *testing.T) { func TestSetChangeAddressBech32(t *testing.T) { cc := apollo.NewEmptyBackend() apollob := apollo.New(&cc) - apollob = apollob.SetChangeAddressBech32("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu").AddInput(InputUtxo) + apollob = apollob.SetChangeAddressBech32("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu"). + AddInput(InputUtxo) built, err := apollob.Complete() if err != nil { t.Error(err) } - if built.GetTx().TransactionBody.Outputs[0].GetAddress().String() != "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu" { + if built.GetTx().TransactionBody.Outputs[0].GetAddress(). + String() != + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu" { t.Error("Tx is not correct") } } @@ -1069,7 +1250,8 @@ func TestSetChangeAddressBech32(t *testing.T) { func TestSetWalletFromBech32(t *testing.T) { cc := apollo.NewEmptyBackend() apollob := apollo.New(&cc) - apollob, err := apollob.SetWalletFromBech32("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu").SetWalletAsChangeAddress() + apollob, err := apollob.SetWalletFromBech32("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu"). + SetWalletAsChangeAddress() if err != nil { t.Error(err) } @@ -1078,7 +1260,9 @@ func TestSetWalletFromBech32(t *testing.T) { if err != nil { t.Error(err) } - if built.GetTx().TransactionBody.Outputs[0].GetAddress().String() != "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu" { + if built.GetTx().TransactionBody.Outputs[0].GetAddress(). + String() != + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu" { t.Error("Tx is not correct") } } @@ -1086,24 +1270,32 @@ func TestSetWalletFromBech32(t *testing.T) { func TestRefInput(t *testing.T) { cc := apollo.NewEmptyBackend() apollob := apollo.New(&cc) - apollob, err := apollob.SetWalletFromBech32("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu").SetWalletAsChangeAddress() + apollob, err := apollob.SetWalletFromBech32("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu"). + SetWalletAsChangeAddress() if err != nil { t.Error(err) } apollob = apollob.AddInput(InputUtxo). - AddReferenceInput(hex.EncodeToString(InputUtxo.Input.TransactionId), 0).AddCollateral(collateralUtxo) + AddReferenceInput(hex.EncodeToString(InputUtxo.Input.TransactionId), 0). + AddCollateral(collateralUtxo) built, err := apollob.Complete() if err != nil { t.Error(err) } - if hex.EncodeToString(built.GetTx().TransactionBody.ReferenceInputs[0].TransactionId) != hex.EncodeToString(InputUtxo.Input.TransactionId) { + if hex.EncodeToString( + built.GetTx().TransactionBody.ReferenceInputs[0].TransactionId, + ) != hex.EncodeToString( + InputUtxo.Input.TransactionId, + ) { t.Error("Tx is not correct") } } func TestExactComplete(t *testing.T) { cc := apollo.NewEmptyBackend() - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) apollob := apollo.New(&cc) redeemer := Redeemer.Redeemer{ Tag: Redeemer.SPEND, @@ -1120,7 +1312,8 @@ func TestExactComplete(t *testing.T) { utxos := testutils.InitUtxosDifferentiated() apollob = apollob.SetChangeAddress(decoded_addr).AddLoadedUTxOs(utxos...). - CollectFrom(InputUtxo, redeemer).AttachDatum(&datum).AttachV1Script([]byte("Hello, World!")).SetEstimationExUnitsRequired() + CollectFrom(InputUtxo, redeemer). + AttachDatum(&datum).AttachV1Script([]byte("Hello, World!")).SetEstimationExUnitsRequired() built, err := apollob.CompleteExact(200_000) if err != nil { t.Error(err) @@ -1177,7 +1370,9 @@ func TestExactComplete(t *testing.T) { func TestCongestedBuild(t *testing.T) { cc := apollo.NewEmptyBackend() - decoded_addr, _ := Address.DecodeAddress("addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu") + decoded_addr, _ := Address.DecodeAddress( + "addr1qy99jvml0vafzdpy6lm6z52qrczjvs4k362gmr9v4hrrwgqk4xvegxwvtfsu5ck6s83h346nsgf6xu26dwzce9yvd8ysd2seyu", + ) apollob := apollo.New(&cc) utxos := testutils.InitUtxosCongested() apollob = apollob.SetChangeAddress(decoded_addr).AddLoadedUTxOs(utxos...). @@ -1278,7 +1473,9 @@ func TestMapWithCbor(t *testing.T) { if err != nil { t.Error(err) } - if hex.EncodeToString(encoded) != "d879a3457072696365186447656e64446174651864497374617274446174651864" { + if hex.EncodeToString( + encoded, + ) != "d879a3457072696365186447656e64446174651864497374617274446174651864" { t.Error(hex.EncodeToString(encoded)) break } @@ -1316,7 +1513,9 @@ func TestScriptDataHashConway(t *testing.T) { t.Error(err) } fmt.Println(WitnessSet.Redeemer) - if hex.EncodeToString(hash.Payload) != "02b4dbcdbb671e62b2c4e5bd39082ca85c181f349c48d1a588670300b4b6dcb8" { + if hex.EncodeToString( + hash.Payload, + ) != "02b4dbcdbb671e62b2c4e5bd39082ca85c181f349c48d1a588670300b4b6dcb8" { t.Error("Tx is not correct", hex.EncodeToString(hash.Payload)) } } @@ -1327,7 +1526,9 @@ func TestEmptyRedeemerHashConway(t *testing.T) { if err != nil { t.Error(err) } - if hex.EncodeToString(hash.Payload) != "9eb0251b2e85b082c3706a3e79b4cf2a2e96f936e912a398591e2486c757f8c1" { + if hex.EncodeToString( + hash.Payload, + ) != "9eb0251b2e85b082c3706a3e79b4cf2a2e96f936e912a398591e2486c757f8c1" { t.Error("Tx is not correct", hex.EncodeToString(hash.Payload)) } diff --git a/apollotypes/types.go b/apollotypes/types.go index 3340cdf..ba58c70 100644 --- a/apollotypes/types.go +++ b/apollotypes/types.go @@ -9,13 +9,17 @@ import ( "github.com/Salvionied/apollo/serialization/Transaction" "github.com/Salvionied/apollo/serialization/TransactionWitnessSet" "github.com/Salvionied/apollo/serialization/UTxO" + "github.com/Salvionied/apollo/serialization/VerificationKeyWitness" "github.com/Salvionied/apollo/txBuilding/Backend/Base" ) type Wallet interface { GetAddress() *serAddress.Address - SignTx(tx Transaction.Transaction, usedUtxos []UTxO.UTxO) TransactionWitnessSet.TransactionWitnessSet + SignTx( + tx Transaction.Transaction, + usedUtxos []UTxO.UTxO, + ) TransactionWitnessSet.TransactionWitnessSet PkeyHash() serialization.PubKeyHash SkeyHash() serialization.PubKeyHash //SignMessage(address serAddress.Address, message []uint8) []uint8 @@ -46,9 +50,14 @@ func (ew *ExternalWallet) GetAddress() *serAddress.Address { tx (Transaction.Transaction): The transaction to be signed. Returns: - TransactionWitnessSet.TransactionWitnessSet: The withness set associated with the signed transaction. + + + TransactionWitnessSet.TransactionWitnessSet: The withness set associated with the signed transaction. */ -func (ew *ExternalWallet) SignTx(tx Transaction.Transaction, usedUtxos []UTxO.UTxO) TransactionWitnessSet.TransactionWitnessSet { +func (ew *ExternalWallet) SignTx( + tx Transaction.Transaction, + usedUtxos []UTxO.UTxO, +) TransactionWitnessSet.TransactionWitnessSet { return tx.TransactionWitnessSet } @@ -68,21 +77,24 @@ func (ew *ExternalWallet) PkeyHash() serialization.PubKeyHash { } func (ew *ExternalWallet) SkeyHash() serialization.PubKeyHash { - return serialization.PubKeyHash{} + res := serialization.PubKeyHash(ew.Address.StakingPart) + return res } type GenericWallet struct { SigningKey Key.SigningKey VerificationKey Key.VerificationKey Address serAddress.Address - StakeSigningKey Key.StakeSigningKey - StakeVerificationKey Key.StakeVerificationKey + StakeSigningKey Key.SigningKey + StakeVerificationKey Key.VerificationKey } /* * - PkeyHash calculates and returns the public key hash associated with a generic wallet. + PkeyHash calculates and returns the public key hash associated with a generic wallet. + + It computes the public key hash by calling the Hash() method on the wallet's VerificationKey. Then it returns as a serialization.PubKeyHas type. @@ -114,17 +126,23 @@ func (gw *GenericWallet) GetAddress() *serAddress.Address { /* * - SignTx signs a transaction using a generic wallet and returns the updated TransactionWitnessSet. - It takes a transaction of type Transaction.Transaction and signs it using the wallet's SigningKey. - Then it appends the corresponding VerificationKeyWitness to the TransactionWitnessSet and returns - the updated witness set. + SignTx signs a transaction using a generic wallet and returns the updated TransactionWitnessSet. - Parameters: - wallet (*GenericWallet): A pointer to a generic wallet. - tx (Transaction.Transaction): The transaction to be signed. - Returns: - TransactionWitnessSet.TransactionWitnessSet: The updated TransactionWitnessSet after signing the transaction. + It takes a transaction of type Transaction.Transaction and signs it using the wallet's SigningKey. + + + Then it appends the corresponding VerificationKeyWitness to the TransactionWitnessSet and returns + the updated witness set. + + Parameters: + wallet (*GenericWallet): A pointer to a generic wallet. + tx (Transaction.Transaction): The transaction to be signed. + + Returns: + + + TransactionWitnessSet.TransactionWitnessSet: The updated TransactionWitnessSet after signing the transaction. */ func (wallet *GenericWallet) SignTx( tx Transaction.Transaction, diff --git a/serialization/Key/Key.go b/serialization/Key/Key.go index e6e7308..8bd2c2e 100644 --- a/serialization/Key/Key.go +++ b/serialization/Key/Key.go @@ -66,28 +66,6 @@ func (sk SigningKey) Sign(data []byte) ([]byte, error) { return signature, nil } -/* -* - - Sign function signs a data byte slice using - the signing key and the returns the signature. - - Params: - data ([]byte): The data to sign. - - Returns: - []byte: The signature of the data. - error: An error if the signing fails. -*/ -func (sk StakeSigningKey) Sign(data []byte) ([]byte, error) { - pk := sk.Payload - signature, err := Sign(data, pk) - if err != nil { - return nil, err - } - return signature, nil -} - type VerificationKey struct { Payload []byte } @@ -171,16 +149,6 @@ func (vk VerificationKey) Hash() (serialization.PubKeyHash, error) { return r, nil } -func (vsk StakeVerificationKey) Hash() (serialization.PubKeyHash, error) { - KeyHash, err := Blake224Hash(vsk.Payload, 28) - if err != nil { - return serialization.PubKeyHash{}, err - } - r := serialization.PubKeyHash{} - copy(r[:], KeyHash) - return r, nil -} - type PaymentKeyPair struct { VerificationKey VerificationKey SigningKey SigningKey @@ -206,8 +174,6 @@ func PaymentKeyPairGenerate() (*PaymentKeyPair, error) { type PaymentSigningKey SigningKey type PaymentVerificationKey VerificationKey -type StakeSigningKey SigningKey -type StakeVerificationKey VerificationKey /* *