Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

script.toBytes() returning empty bytes #1796

Open
v4v2 opened this issue Jan 10, 2025 · 7 comments
Open

script.toBytes() returning empty bytes #1796

v4v2 opened this issue Jan 10, 2025 · 7 comments
Labels
bug Something isn't working

Comments

@v4v2
Copy link

v4v2 commented Jan 10, 2025

Describe the bug

The toBytes() method of Script is returning empty array on Signet.
I am using a port of BDK to typescript.

To Reproduce

  const inputs = await transaction.input()
  for (const index in inputs) {
      const input = inputs[index]
      const script = await input.scriptSig.toBytes() // THIS IS EMPTY
      input.scriptSig = script
      vin.push(input)
    }
// more ... code

the inputs is an array of TxIn with the fields sequence, previousOutput, witness, but the sigScript which is of type Script is returning empty bytes.

Expected behavior
Get the input script as bytes or hex.

Build environment

  • BDK tag/commit: (how to figure out? I guess it is the latest....)
  • OS+version: ArchLinux latest (using kernel 6.x)
  • Rust/Cargo version: 1.83
  • Rust/Cargo target: x86_64-unknown-linux-gnu

Additional context
Signet

Thanks in advance 👍

@v4v2 v4v2 added the bug Something isn't working label Jan 10, 2025
@v4v2
Copy link
Author

v4v2 commented Jan 10, 2025

if this is indeed a bug and not a misuse from my part, I offer help to fix 👍

@notmandatory
Copy link
Member

You said you're using a port of BDK to typescript, which project is that?

@notmandatory notmandatory added this to BDK Jan 12, 2025
@notmandatory notmandatory moved this to Discussion in BDK Jan 12, 2025
@v4v2
Copy link
Author

v4v2 commented Jan 16, 2025

@Psycarlo please help me explain how we are using BDK in typescript in our project

@Psycarlo
Copy link

We are using bdk-rn

@Psycarlo
Copy link

Our app is crashing trying to build a transaction.
Looks like it crashes when using addRecipient

transactionBuilder.addRecipient(script, amount) // TODO: crashing here

Script is being created like this:

const address = await new Address().create(recipient) // recipient is the address string
const script = await address.scriptPubKey()

@Psycarlo
Copy link

Silly me

When I was building the transaction, I was not awaiting.
For example,

transactionBuilder.feeAbsolute(fee)

instead of

await transactionBuilder.feeAbsolute(fee)

@pedromvpg
Copy link

pedromvpg commented Jan 22, 2025

You said you're using a port of BDK to typescript, which project is that?

@notmandatory it's happening on SatSigner. Here's where we're getting the issue: https://github.com/satsigner/satsigner/blob/7a928cd52d777568f6ee1a746ec7eb7be60ad3d9/apps/mobile/api/bdk.ts#L220

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
Status: Discussion
Development

No branches or pull requests

4 participants