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

# Get send transaction status

> Get the status of a send transaction request.

export const EndpointPath = ({type, path}) => {
  return <div class="flex w-full flex-col bg-background-light dark:bg-background-dark border-standard rounded-2xl p-1.5">
      <div class="flex items-center space-x-1.5">
        <div class="relative flex-1 flex gap-2 min-w-0 rounded-xl items-center cursor-pointer p-1.5 border-standard">
          <div class="rounded-lg font-bold px-1.5 py-0.5 text-sm leading-5 bg-blue-400/20 dark:bg-blue-400/20 text-blue-700 dark:text-blue-400">
            POST
          </div>
          <div class="flex items-center space-x-2 overflow-x-auto flex-1 no-scrollbar">
            <div class="group flex items-center flex-1 gap-0.5 font-mono">
              <div class="absolute right-0 p-2 bg-background-light dark:bg-background-dark rounded-lg hidden group-hover:block">
                <svg class="w-4 h-4 bg-gray-400 dark:bg-white/30"></svg>
              </div>
              <div class="text-sm text-gray-400">/</div>
              <div class="text-sm font-medium text-gray-800 dark:text-white min-w-max">
                public
              </div>
              <div class="text-sm text-gray-400">/</div>
              <div class="text-sm font-medium text-gray-800 dark:text-white min-w-max">
                v1
              </div>
              <div class="text-sm text-gray-400">/</div>
              <div class="text-sm font-medium text-gray-800 dark:text-white min-w-max">
                {type}
              </div>
              <div class="text-sm text-gray-400">/</div>
              <div class="text-sm font-medium text-gray-800 dark:text-white min-w-max">
                {path}
              </div>
            </div>
          </div>
        </div>
      </div>
    </div>;
};

export const NestedParam = ({parentKey, childKey, type, required, description, children}) => {
  const fullKey = `${parentKey}.${childKey}`;
  const anchorId = `body-${fullKey.replace(/\./g, '-')}`;
  return <div className="py-6 border-gray-100 dark:border-gray-800 border-b last:border-b-0">
  <div className="flex font-mono text-sm group/param-head param-head break-all relative" id={anchorId}>
    <div className="flex-1 flex content-start py-0.5 mr-5">
      <div className="flex items-center flex-wrap gap-2">
        <div className="absolute -top-1.5">
          <a href={`#${anchorId}`} className="-ml-[2.1rem] flex items-center opacity-0 border-0 group-hover/param-head:opacity-100 py-2 [.expandable-content_&]:-ml-[2.1rem]" aria-label="Navigate to header">
            <div className="w-6 h-6 text-gray-400 rounded-md flex items-center justify-center zinc-box bg-white ring-1 ring-gray-400/30 dark:ring-gray-700/25 hover:ring-gray-400/60 dark:hover:ring-white/20">
              <svg xmlns="http://www.w3.org/2000/svg" fill="gray" height="12px" viewBox="0 0 576 512">
                <path d="M0 256C0 167.6 71.6 96 160 96h72c13.3 0 24 10.7 24 24s-10.7 24-24 24H160C98.1 144 48 194.1 48 256s50.1 112 112 112h72c13.3 0 24 10.7 24 24s-10.7 24-24 24H160C71.6 416 0 344.4 0 256zm576 0c0 88.4-71.6 160-160 160H344c-13.3 0-24-10.7-24-24s10.7-24 24-24h72c61.9 0 112-50.1 112-112s-50.1-112-112-112H344c-13.3 0-24-10.7-24-24s10.7-24 24-24h72c88.4 0 160 71.6 160 160zM184 232H392c13.3 0 24 10.7 24 24s-10.7 24-24 24H184c-13.3 0-24-10.7-24-24s10.7-24 24-24z"></path>
              </svg>
            </div>
          </a>
        </div>
        <div className="font-semibold text-primary dark:text-primary-light cursor-pointer overflow-wrap-anywhere">
          <span className="text-gray-500 dark:text-gray-400">{parentKey}.</span>
          {childKey}
        </div>
        <div className="inline items-center gap-2 text-xs font-medium [&_div]:inline [&_div]:mr-2 [&_div]:leading-5">
          <div className="flex items-center px-2 py-0.5 rounded-md bg-gray-100/50 dark:bg-white/5 text-gray-600 dark:text-gray-200 font-medium break-all">
            <span>{type}</span>
          </div>
          {required && <span className="px-2 py-0.5 rounded-md bg-red-100/50 dark:bg-red-400/10 text-red-600 dark:text-red-300 font-medium whitespace-nowrap">
              required
            </span>}
        </div>
      </div>
    </div>
  </div>
  {children && <div className="mt-4">
      <div className="prose prose-sm prose-gray dark:prose-invert">
        {children}
      </div>
    </div>}
</div>;
};

export const H3Bordered = ({text}) => <h3 id={text.toLowerCase()} className="border-b pb-2.5 border-gray-100 dark:border-gray-800">
    {text}
  </h3>;

export const Authorizations = () => {
  return <div>
      <H3Bordered text="Authorizations" />

      <Tabs>
        <Tab title="API Key">
          <div className="flex text-sm group/param-head param-head break-all relative" id="authorization-x-stamp">
            <ParamField header="X-Stamp" type="string" required={true}>
              Cryptographically signed (stamped) request to be passed in as a header. For more info, see <a href="https://docs.turnkey.com/developer-reference/api-overview/stamps">here</a>.
            </ParamField>
          </div>
        </Tab>

        <Tab title="WebAuthn (Passkey)">
         <div className="flex text-sm group/param-head param-head break-all relative" id="authorization-x-stamp-webauthn">
            <ParamField body="X-Stamp-WebAuthn" type="string" required={true}>
              Cryptographically signed (stamped) request to be passed in as a header. For more info, see <a href="https://docs.turnkey.com/developer-reference/api-overview/stamps">here</a>.
            </ParamField>
          </div>
        </Tab>
      </Tabs>
    </div>;
};

<EndpointPath type="query" path="get_send_transaction_status" />

<Authorizations />

<H3Bordered text="Body" />

<ParamField body="organizationId" type="string" required={true}>
  Unique identifier for a given organization.
</ParamField>

<ParamField body="sendTransactionStatusId" type="string" required={true}>
  The unique identifier of a send transaction request.
</ParamField>

<H3Bordered text="Response" />

A successful response returns the following fields:

<ResponseField name="txStatus" type="string" required={true}>The current status of the send transaction.</ResponseField>

<ResponseField name="eth" type="object" required={false}>
  eth field

  <Expandable title="eth details">
    <NestedParam parentKey="eth" childKey="txHash" type="string" required={false}>
      The Ethereum transaction hash, if available.
    </NestedParam>
  </Expandable>
</ResponseField>

<ResponseField name="solana" type="object" required={false}>
  solana field

  <Expandable title="solana details">
    <NestedParam parentKey="solana" childKey="signature" type="string" required={false}>
      The Solana transaction signature, if available.
    </NestedParam>
  </Expandable>
</ResponseField>

<ResponseField name="txError" type="string" required={false}>The error encountered when broadcasting or confirming the transaction, if any.</ResponseField>

<ResponseField name="error" type="object" required={false}>
  error field

  <Expandable title="error details">
    <NestedParam parentKey="error" childKey="message" type="string" required={false}>
      Human-readable error message describing what went wrong.
    </NestedParam>

    <NestedParam parentKey="error" childKey="revertChain" type="array" required={false}>
      Chain of revert errors from nested contract calls, ordered from outermost to innermost.

      <Expandable title="revertChain details">
        <NestedParam parentKey="error.revertChain" childKey="address" type="string" required={false}>
          The contract address where the revert occurred.
        </NestedParam>

        <NestedParam parentKey="error.revertChain" childKey="errorType" type="string" required={false}>
          Type of error: 'unknown', 'native', or 'custom'.
        </NestedParam>

        <NestedParam parentKey="error.revertChain" childKey="displayMessage" type="string" required={false}>
          Human-readable message describing this revert.
        </NestedParam>

        <NestedParam parentKey="error.revertChain" childKey="unknown" type="object" required={false}>
          unknown field

          <Expandable title="unknown details">
            <NestedParam parentKey="error.revertChain.unknown" childKey="selector" type="string" required={false}>
              The 4-byte error selector, if available.
            </NestedParam>

            <NestedParam parentKey="error.revertChain.unknown" childKey="data" type="string" required={false}>
              The raw error data, hex-encoded.
            </NestedParam>
          </Expandable>
        </NestedParam>

        <NestedParam parentKey="error.revertChain" childKey="native" type="object" required={false}>
          native field

          <Expandable title="native details">
            <NestedParam parentKey="error.revertChain.native" childKey="nativeType" type="string" required={false}>
              The type of native error: 'error\_string', 'panic', or 'execution\_reverted'.
            </NestedParam>

            <NestedParam parentKey="error.revertChain.native" childKey="message" type="string" required={false}>
              The error message for Error(string) reverts.
            </NestedParam>

            <NestedParam parentKey="error.revertChain.native" childKey="panicCode" type="string" required={false}>
              The panic code for Panic(uint256) reverts.
            </NestedParam>
          </Expandable>
        </NestedParam>

        <NestedParam parentKey="error.revertChain" childKey="custom" type="object" required={false}>
          custom field

          <Expandable title="custom details">
            <NestedParam parentKey="error.revertChain.custom" childKey="errorName" type="string" required={false}>
              The name of the custom error.
            </NestedParam>

            <NestedParam parentKey="error.revertChain.custom" childKey="paramsJson" type="string" required={false}>
              The decoded parameters as a JSON object.
            </NestedParam>
          </Expandable>
        </NestedParam>
      </Expandable>
    </NestedParam>

    <NestedParam parentKey="error" childKey="solana" type="object" required={false}>
      solana field

      <Expandable title="solana details">
        <NestedParam parentKey="error.solana" childKey="source" type="string" required={false}>
          Where the Solana failure occurred, such as simulation or preflight.
        </NestedParam>

        <NestedParam parentKey="error.solana" childKey="rpcCode" type="number" required={false}>
          The Solana JSON-RPC error code, if available.
        </NestedParam>

        <NestedParam parentKey="error.solana" childKey="rpcMessage" type="string" required={false}>
          The Solana JSON-RPC error message, if available.
        </NestedParam>

        <NestedParam parentKey="error.solana" childKey="transactionErrorJson" type="string" required={false}>
          The raw Solana transaction error object serialized as JSON, if available.
        </NestedParam>

        <NestedParam parentKey="error.solana" childKey="logs" type="array" required={false}>
          Program logs returned by Solana simulation or preflight, if available.

          <Expandable title="logs details">
            <NestedParam parentKey="error.solana.logs" childKey="item" type="string" required={true}>
              item field
            </NestedParam>
          </Expandable>
        </NestedParam>

        <NestedParam parentKey="error.solana" childKey="unitsConsumed" type="string" required={false}>
          Compute units consumed during simulation or preflight, if available.
        </NestedParam>

        <NestedParam parentKey="error.solana" childKey="innerInstructionsJson" type="string" required={false}>
          The raw Solana inner instructions payload serialized as JSON, if available.
        </NestedParam>
      </Expandable>
    </NestedParam>

    <NestedParam parentKey="error" childKey="eth" type="object" required={false}>
      eth field

      <Expandable title="eth details">
        <NestedParam parentKey="error.eth" childKey="revertChain" type="array" required={false}>
          Ethereum revert chain, ordered from outermost to innermost.

          <Expandable title="revertChain details">
            <NestedParam parentKey="error.eth.revertChain" childKey="address" type="string" required={false}>
              The contract address where the revert occurred.
            </NestedParam>

            <NestedParam parentKey="error.eth.revertChain" childKey="errorType" type="string" required={false}>
              Type of error: 'unknown', 'native', or 'custom'.
            </NestedParam>

            <NestedParam parentKey="error.eth.revertChain" childKey="displayMessage" type="string" required={false}>
              Human-readable message describing this revert.
            </NestedParam>

            <NestedParam parentKey="error.eth.revertChain" childKey="unknown" type="object" required={false}>
              unknown field

              <Expandable title="unknown details">
                <NestedParam parentKey="error.eth.revertChain.unknown" childKey="selector" type="string" required={false}>
                  The 4-byte error selector, if available.
                </NestedParam>

                <NestedParam parentKey="error.eth.revertChain.unknown" childKey="data" type="string" required={false}>
                  The raw error data, hex-encoded.
                </NestedParam>
              </Expandable>
            </NestedParam>

            <NestedParam parentKey="error.eth.revertChain" childKey="native" type="object" required={false}>
              native field

              <Expandable title="native details">
                <NestedParam parentKey="error.eth.revertChain.native" childKey="nativeType" type="string" required={false}>
                  The type of native error: 'error\_string', 'panic', or 'execution\_reverted'.
                </NestedParam>

                <NestedParam parentKey="error.eth.revertChain.native" childKey="message" type="string" required={false}>
                  The error message for Error(string) reverts.
                </NestedParam>

                <NestedParam parentKey="error.eth.revertChain.native" childKey="panicCode" type="string" required={false}>
                  The panic code for Panic(uint256) reverts.
                </NestedParam>
              </Expandable>
            </NestedParam>

            <NestedParam parentKey="error.eth.revertChain" childKey="custom" type="object" required={false}>
              custom field

              <Expandable title="custom details">
                <NestedParam parentKey="error.eth.revertChain.custom" childKey="errorName" type="string" required={false}>
                  The name of the custom error.
                </NestedParam>

                <NestedParam parentKey="error.eth.revertChain.custom" childKey="paramsJson" type="string" required={false}>
                  The decoded parameters as a JSON object.
                </NestedParam>
              </Expandable>
            </NestedParam>
          </Expandable>
        </NestedParam>
      </Expandable>
    </NestedParam>
  </Expandable>
</ResponseField>

<RequestExample>
  ```bash title="cURL" theme={"system"}
  curl --request POST \
    --url https://api.turnkey.com/public/v1/query/get_send_transaction_status \
    --header 'Accept: application/json' \
    --header 'Content-Type: application/json' \
    --header "X-Stamp: <string> (see Authorizations)" \
    --data '{
      "organizationId": "<string>",
      "sendTransactionStatusId": "<string>"
  }'
  ```

  ```javascript title="JavaScript" theme={"system"}
  import { Turnkey } from "@turnkey/sdk-server";

  const turnkeyClient = new Turnkey({
    apiBaseUrl: "https://api.turnkey.com",
    apiPublicKey: process.env.API_PUBLIC_KEY!,
    apiPrivateKey: process.env.API_PRIVATE_KEY!,
    defaultOrganizationId: process.env.ORGANIZATION_ID!,
  });

  const response = await turnkeyClient.apiClient().getSendTransactionStatus({
    organizationId: "<string> (Unique identifier for a given organization.)",
    sendTransactionStatusId: "<string> (The unique identifier of a send transaction request.)"
  });
  ```
</RequestExample>

<ResponseExample>
  ```json 200 theme={"system"}
  {
    "txStatus": "<string>",
    "eth": {
      "txHash": "<string>"
    },
    "solana": {
      "signature": "<string>"
    },
    "txError": "<string>",
    "error": {
      "message": "<string>",
      "revertChain": [
        {
          "address": "<string>",
          "errorType": "<string>",
          "displayMessage": "<string>",
          "unknown": {
            "selector": "<string>",
            "data": "<string>"
          },
          "native": {
            "nativeType": "<string>",
            "message": "<string>",
            "panicCode": "<string>"
          },
          "custom": {
            "errorName": "<string>",
            "paramsJson": "<string>"
          }
        }
      ],
      "solana": {
        "source": "<string>",
        "rpcCode": "<number>",
        "rpcMessage": "<string>",
        "transactionErrorJson": "<string>",
        "logs": [
          "<string>"
        ],
        "unitsConsumed": "<string>",
        "innerInstructionsJson": "<string>"
      },
      "eth": {
        "revertChain": [
          {
            "address": "<string>",
            "errorType": "<string>",
            "displayMessage": "<string>",
            "unknown": {
              "selector": "<string>",
              "data": "<string>"
            },
            "native": {
              "nativeType": "<string>",
              "message": "<string>",
              "panicCode": "<string>"
            },
            "custom": {
              "errorName": "<string>",
              "paramsJson": "<string>"
            }
          }
        ]
      }
    }
  }
  ```
</ResponseExample>
