UNPKG

viem

Version:

TypeScript Interface for Ethereum

45 lines 1.62 kB
import { parseEventLogs } from '../../utils/abi/parseEventLogs.js'; import { formatLog, } from '../../utils/formatters/log.js'; /** * Returns a list of event logs since the filter was created. * * - Docs: https://viem.sh/docs/actions/public/getFilterLogs * - JSON-RPC Methods: [`eth_getFilterLogs`](https://ethereum.org/en/developers/docs/apis/json-rpc/#eth_getfilterlogs) * * `getFilterLogs` is only compatible with **event filters**. * * @param client - Client to use * @param parameters - {@link GetFilterLogsParameters} * @returns A list of event logs. {@link GetFilterLogsReturnType} * * @example * import { createPublicClient, http, parseAbiItem } from 'viem' * import { mainnet } from 'viem/chains' * import { createEventFilter, getFilterLogs } from 'viem/public' * * const client = createPublicClient({ * chain: mainnet, * transport: http(), * }) * const filter = await createEventFilter(client, { * address: '0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48', * event: parseAbiItem('event Transfer(address indexed, address indexed, uint256)'), * }) * const logs = await getFilterLogs(client, { filter }) */ export async function getFilterLogs(_client, { filter, }) { const strict = filter.strict ?? false; const logs = await filter.request({ method: 'eth_getFilterLogs', params: [filter.id], }); const formattedLogs = logs.map((log) => formatLog(log)); if (!filter.abi) return formattedLogs; return parseEventLogs({ abi: filter.abi, logs: formattedLogs, strict, }); } //# sourceMappingURL=getFilterLogs.js.map