> ## Documentation Index
> Fetch the complete documentation index at: https://docs.chainstack.com/llms.txt
> Use this file to discover all available pages before exploring further.

# debug_getRawTransaction | Hyperliquid EVM

> The debug_getRawTransaction JSON-RPC method returns the raw transaction data for a specific transaction. Hyperliquid EVM via Chainstack.

<Info>
  This method is available on Chainstack. Not all Hyperliquid methods are available on Chainstack, as the open-source node implementation does not support them yet — see [Hyperliquid methods](/docs/hyperliquid-methods) for the full availability breakdown.
</Info>

The `debug_getRawTransaction` JSON-RPC method returns the raw transaction data for a specific transaction. This method provides the complete transaction in its raw encoded format, useful for low-level transaction analysis, custom parsing, and applications that need direct access to the transaction's binary representation.

## Parameters

1. **Transaction hash** (string, required): The hash of the transaction to retrieve

## Response

The method returns the raw transaction data in hexadecimal format.

### Response structure

**Raw transaction data:**

* `result` — Complete raw transaction data encoded in hexadecimal format

## Usage example

### Basic implementation

```javascript theme={"system"}
// Get raw transaction data
const getRawTransaction = async (txHash) => {
  const response = await fetch('https://hyperliquid-mainnet.core.chainstack.com/YOUR_ENDPOINT/evm', {
    method: 'POST',
    headers: {
      'Content-Type': 'application/json',
    },
    body: JSON.stringify({
      jsonrpc: '2.0',
      method: 'debug_getRawTransaction',
      params: [txHash],
      id: 1
    })
  });
  
  const data = await response.json();
  return data.result;
};

// Usage
const txHash = '0x07712544ce8f50091c6c3b227921f763b342bf9465a22f0226d651a3246adb31';
getRawTransaction(txHash).then(rawTx => {
  console.log('Raw transaction:', rawTx);
  console.log('Transaction size:', rawTx.length / 2 - 1, 'bytes');
});
```

## Example request

<CodeGroup>
  ```shell Shell theme={"system"}
  curl -X POST \
    -H "Content-Type: application/json" \
    -d '{
      "jsonrpc": "2.0",
      "method": "debug_getRawTransaction",
      "params": [
        "0x07712544ce8f50091c6c3b227921f763b342bf9465a22f0226d651a3246adb31"
      ],
      "id": 1
    }' \
    https://hyperliquid-mainnet.core.chainstack.com/4f8d8f4040bdacd1577bff8058438274/evm
  ```

  ```python web3.py theme={"system"}
  from web3 import Web3

  w3 = Web3(Web3.HTTPProvider("YOUR_CHAINSTACK_ENDPOINT"))

  tx_hash = "0x07712544ce8f50091c6c3b227921f763b342bf9465a22f0226d651a3246adb31"

  # debug_getRawTransaction has no typed wrapper, so call it directly
  response = w3.provider.make_request("debug_getRawTransaction", [tx_hash])
  print(response["result"])
  ```

  ```javascript ethers.js theme={"system"}
  import { JsonRpcProvider } from "ethers";

  const provider = new JsonRpcProvider("YOUR_CHAINSTACK_ENDPOINT");

  const txHash =
    "0x07712544ce8f50091c6c3b227921f763b342bf9465a22f0226d651a3246adb31";

  // debug_getRawTransaction has no typed wrapper, so use the generic send
  const rawTx = await provider.send("debug_getRawTransaction", [txHash]);
  console.log(rawTx);
  ```

  ```typescript viem theme={"system"}
  import { createPublicClient, http } from "viem";

  const client = createPublicClient({
    transport: http("YOUR_CHAINSTACK_ENDPOINT"),
  });

  const txHash =
    "0x07712544ce8f50091c6c3b227921f763b342bf9465a22f0226d651a3246adb31";

  // debug_getRawTransaction has no typed action, so use the raw request method
  const rawTx = await client.request({
    method: "debug_getRawTransaction",
    params: [txHash],
  });
  console.log(rawTx);
  ```
</CodeGroup>

<Note>
  **Use your own endpoint in your code.** The code examples use a placeholder Chainstack endpoint (YOUR\_CHAINSTACK\_ENDPOINT) — replace it with your own Hyperliquid node endpoint from the [Chainstack console](https://console.chainstack.com/). The curl above uses a shared public endpoint for quick checks only; do not use it in production.
</Note>

## Use cases

The `debug_getRawTransaction` method is essential for applications that need to:

* **Transaction analysis**: Perform low-level analysis of transaction structures
* **Custom parsing**: Implement custom transaction parsing and validation
* **Development tools**: Build transaction debugging and analysis tools
* **Data archival**: Archive complete transaction data in raw format
* **Forensic investigation**: Perform detailed forensic analysis of transactions
* **Protocol research**: Research transaction format and encoding details
* **Cross-chain verification**: Verify transactions across different systems
* **Security analysis**: Analyze transaction security and validation
* **Academic research**: Support academic research on blockchain transactions
* **Compliance tools**: Build regulatory compliance and auditing systems

This method provides direct access to raw transaction data for comprehensive analysis on the Hyperliquid EVM platform.


## OpenAPI

````yaml openapi/hyperliquid_node_api/hyperevm/evm_debug_get_raw_transaction.json post /evm
openapi: 3.0.0
info:
  title: Hyperliquid EVM API - debug_getRawTransaction
  version: 1.0.0
servers:
  - url: >-
      https://hyperliquid-mainnet.core.chainstack.com/4f8d8f4040bdacd1577bff8058438274
security: []
paths:
  /evm:
    post:
      summary: debug_getRawTransaction
      description: >-
        Returns the raw transaction data for a specific transaction. This method
        provides the complete transaction in its raw encoded format, useful for
        low-level analysis and debugging.
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: object
              required:
                - jsonrpc
                - method
                - params
                - id
              properties:
                jsonrpc:
                  type: string
                  enum:
                    - '2.0'
                  default: '2.0'
                  description: JSON-RPC version
                method:
                  type: string
                  enum:
                    - debug_getRawTransaction
                  default: debug_getRawTransaction
                  description: The RPC method name
                params:
                  type: array
                  description: 'Parameters: [transaction hash]'
                  default:
                    - >-
                      0x07712544ce8f50091c6c3b227921f763b342bf9465a22f0226d651a3246adb31
                id:
                  type: integer
                  default: 1
                  description: Request identifier
            example:
              jsonrpc: '2.0'
              method: debug_getRawTransaction
              params:
                - >-
                  0x07712544ce8f50091c6c3b227921f763b342bf9465a22f0226d651a3246adb31
              id: 1
      responses:
        '200':
          description: Successful response with raw transaction data
          content:
            application/json:
              schema:
                type: object
                properties:
                  jsonrpc:
                    type: string
                    description: JSON-RPC version
                  id:
                    type: integer
                    description: Request identifier
                  result:
                    type: string
                    description: Raw transaction data in hexadecimal format
              example:
                jsonrpc: '2.0'
                id: 1
                result: 0xf86d80843b9aca0082520894...

````