# settleRailCall

> **settleRailCall**(`options`): [`OutputType`](/reference/filoz/synapse-core/pay/namespaces/settlerailcall/type-aliases/outputtype/)

Defined in: [packages/synapse-core/src/pay/settle-rail.ts:217](https://github.com/FilOzone/synapse-sdk/blob/6cf8b3ed2dd3ae76ed05cb86995d711a08a298a6/packages/synapse-core/src/pay/settle-rail.ts#L217)

Create a call to the settleRail function

This function is used to create a call to the settleRail function for use with
sendCalls, sendTransaction, multicall, estimateContractGas, or simulateContract.

## Parameters

| Parameter | Type | Description |
| ------ | ------ | ------ |
| `options` | [`OptionsType`](/reference/filoz/synapse-core/pay/namespaces/settlerailcall/type-aliases/optionstype/) | [settleRailCall.OptionsType](/reference/filoz/synapse-core/pay/namespaces/settlerailcall/type-aliases/optionstype/) |

## Returns

[`OutputType`](/reference/filoz/synapse-core/pay/namespaces/settlerailcall/type-aliases/outputtype/)

The call to the settleRail function [settleRailCall.OutputType](/reference/filoz/synapse-core/pay/namespaces/settlerailcall/type-aliases/outputtype/)

## Throws

Errors [settleRailCall.ErrorType](/reference/filoz/synapse-core/pay/namespaces/settlerailcall/type-aliases/errortype/)

## Example

```ts
import { settleRailCall } from '@filoz/synapse-core/pay'
import { createWalletClient, http } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { simulateContract } from 'viem/actions'
import { calibration } from '@filoz/synapse-core/chains'

const account = privateKeyToAccount('0x...')
const client = createWalletClient({
  account,
  chain: calibration,
  transport: http(),
})

// Use with simulateContract
const { request } = await simulateContract(client, settleRailCall({
  chain: calibration,
  railId: 1n,
  untilEpoch: 1000n,
}))

console.log(request)
```