Skip to content
This repository has been archived by the owner on Jan 13, 2025. It is now read-only.

Connection.getBlock return types are missing the blockHeight field #1969

Open
jeff-delonge opened this issue Dec 14, 2023 · 3 comments
Open
Labels
1.x Pertains to the v1.x line on the maintenance/v1.x branch bug Something isn't working good first issue Good for newcomers

Comments

@jeff-delonge
Copy link

jeff-delonge commented Dec 14, 2023

Overview

In 1.87.6, the return types of Connection.getBlock such as VersionedBlockResponse and BlockResponse omit the blockHeight field. If Connection.getBlock returns a non-null value, the returned object includes this field.

The types should be updated to include the blockHeight field.

Steps to reproduce

    const connection = new Connection("https://api.mainnet-beta.solana.com", "finalized");
    const latestBlockhashResult = await connection.getLatestBlockhashAndContext("finalized");
    const block = await connection.getBlock(latestBlockhashResult.context.slot, {
        commitment: "finalized",
        maxSupportedTransactionVersion: undefined,
        rewards: false,
        transactionDetails: "none",
    });
    console.log("latestBlockhashResult", latestBlockhashResult);
    console.log("block", block);

Description of bug

The above logs something like the following. Note that the block includes the blockHeight field.

latestBlockhashResult {
  context: { apiVersion: '1.16.18', slot: 235912008 },
  value: {
    blockhash: 'D7Qr3rwEbYKh9cYvV25wmXCcvzJqHxixnZs91tL1Rvsa',
    lastValidBlockHeight: 217323342
  }
}
block {
  blockHeight: 217323042,
  blockTime: 1702587441,
  blockhash: 'D7Qr3rwEbYKh9cYvV25wmXCcvzJqHxixnZs91tL1Rvsa',
  parentSlot: 235912007,
  previousBlockhash: '7vXphDU9znbs6SNBqiyPSEkvJtiZE5D5g55mxw5NKSZk',
  rewards: undefined
}

If instead I try to build the following code (note the const blockHeight = block?.blockHeight), TypeScript will complain because the blockHeight field is missing from the VersionedBlockResponse type in @solana/web3.js:

    const connection = new Connection("https://api.mainnet-beta.solana.com", "finalized");
    const latestBlockhashResult = await connection.getLatestBlockhashAndContext("finalized");
    const block = await connection.getBlock(latestBlockhashResult.context.slot, {
        commitment: "finalized",
        maxSupportedTransactionVersion: undefined,
        rewards: false,
        transactionDetails: "none",
    });
    const blockHeight = block?.blockHeight;
    console.log("latestBlockhashResult", latestBlockhashResult);
    console.log("block", block);

The type error is:

error TS2339: Property 'blockHeight' does not exist on type 'VersionedBlockResponse'.

37     const blockHeight = block?.blockHeight;
@jeff-delonge jeff-delonge added the bug Something isn't working label Dec 14, 2023
@steveluscher
Copy link
Contributor

Thanks! In the meantime, you might be interested in using the new @solana/web3.js that gets this typespec right.

https://stackblitz.com/edit/typescript-gnvm4e?devToolsHeight=33&file=index.ts

More: https://github.com/solana-labs/solana-web3.js/blob/2ac1df6b886bcf335c35651445bd384222cae752/packages/library/README.md

@RaghavenderSingh
Copy link

Hey, I'm interested in working on this one

@buffalojoec
Copy link
Contributor

Hey, I'm interested in working on this one

Please do! Note this is in the legacy library.

@steveluscher steveluscher added the 1.x Pertains to the v1.x line on the maintenance/v1.x branch label Aug 1, 2024
@steveluscher steveluscher added the good first issue Good for newcomers label Oct 24, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
1.x Pertains to the v1.x line on the maintenance/v1.x branch bug Something isn't working good first issue Good for newcomers
Projects
None yet
Development

No branches or pull requests

4 participants