
Company News
Socket Named Top Sales Organization by RepVue
Socket won two 2026 Reppy Awards from RepVue, ranking in the top 5% of all sales orgs. AE Alexandra Lister shares what it's like to grow a sales career here.
@abstraxn/relayer
Advanced tools
Abstraxn Relayer package for handling gas-less transactions, facilitating smart contract interactions, and relaying user transactions efficiently.
The Abstraxn Relayer package is designed for handling gas-less transactions, facilitating smart contract interactions, and efficiently relaying user transactions on the Ethereum blockchain. Now with real-time WebSocket notifications for instant transaction status updates!
Using npm package manager:
npm install @abstraxn/relayer
Or using yarn package manager:
yarn add @abstraxn/relayer
import { Relayer } from "@abstraxn/relayer";
import { ChainId } from "@abstraxn/core-types";
const relayerConfig = {
relayerUrl: "https://your-relayer-url.com",
chainId: ChainId.MAINNET,
signer: yourSignerInstance,
provider: yourProviderInstance,
webSocket: {
enabled: true, // Enable WebSocket real-time updates
autoConnect: true, // Auto-connect on initialization
reconnection: true, // Auto-reconnect on disconnection
},
};
const relayer = new Relayer(relayerConfig);
// Example: Building a relayer transaction
const buildTxParams = {
contractAddress: "0xYourContractAddress",
abi: yourContractAbi,
method: "yourMethodName",
args: ["arg1", "arg2"],
};
// Build and send transaction with real-time updates
relayer.buildRelayerTx(buildTxParams).then(async (txData) => {
console.log("Build Relayer Transaction Response: ", txData);
// Send with real-time WebSocket notifications
const response = await relayer.sendRelayerTxWithRealTimeUpdates({
...txData,
enableRealTimeUpdates: true,
webSocketEvents: {
onTransactionUpdate: (update) => {
console.log(`Transaction ${update.txId} status: ${update.status}`);
if (update.status === 'confirmed') {
console.log('🎉 Transaction confirmed!', update.blockNumber);
}
},
onError: (error) => {
console.error('WebSocket error:', error);
},
},
});
console.log("Transaction ID:", response.transactionId);
});
buildRelayerTx(params: BuildRelayerTxParams)
buildRelayerTxEIP712(params: BuildRelayerTxParams)
sendRelayerTx(params: SendRelayerTxParams)
sendSafeRelayerTx(params: SendSafeRelayerTxParams)
getRelayerTxStatus(transactionId: string)
sendRelayerTxWithRealTimeUpdates(params: SendRelayerTxWithWebSocketParams)
sendSafeRelayerTxWithRealTimeUpdates(params: SendSafeRelayerTxWithWebSocketParams)
subscribeToTransaction(transactionId: string, events?: RelayerWebSocketEvents)
unsubscribeFromTransaction(transactionId: string)
connectWebSocket() / disconnectWebSocket()
isWebSocketConnected(): boolean
interface RelayerWebSocketEvents {
onTransactionUpdate?: (update: TransactionStatusUpdate) => void;
onTransactionCreated?: (event: TransactionCreatedEvent) => void;
onConnect?: () => void;
onDisconnect?: () => void;
onError?: (error: Error) => void;
}
// Subscribe to existing transaction
await relayer.subscribeToTransaction(txId, {
onTransactionUpdate: (update) => {
console.log(`Status: ${update.status}`);
if (update.status === 'confirmed') {
console.log(`Confirmed in block ${update.blockNumber}`);
}
},
});
const txData = await relayer.buildRelayerTx(params);
const response = await relayer.sendRelayerTx(txData);
const finalStatus = await new Promise((resolve, reject) => {
relayer.subscribeToTransaction(response.transactionId, {
onTransactionUpdate: (update) => {
if (update.status === 'confirmed') resolve(update);
if (update.status === 'failed') reject(new Error('Failed'));
},
});
});
const transactions = ['tx1', 'tx2', 'tx3'];
transactions.forEach(txId => {
relayer.subscribeToTransaction(txId, {
onTransactionUpdate: (update) => {
console.log(`[${txId}] Status: ${update.status}`);
},
});
});
const response = await relayer.sendRelayerTx(txData);
// Manual polling required
setInterval(async () => {
const status = await relayer.getRelayerTxStatus(response.transactionId);
console.log(status);
}, 2000);
const response = await relayer.sendRelayerTxWithRealTimeUpdates({
...txData,
enableRealTimeUpdates: true,
webSocketEvents: {
onTransactionUpdate: (update) => console.log(update.status),
},
});
// Instant updates! 🚀
For detailed examples, see WEBSOCKET_EXAMPLES.md.
FAQs
Abstraxn Relayer package for handling gas-less transactions, facilitating smart contract interactions, and relaying user transactions efficiently.
The npm package @abstraxn/relayer receives a total of 20 weekly downloads. As such, @abstraxn/relayer popularity was classified as not popular.
We found that @abstraxn/relayer demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 3 open source maintainers collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Company News
Socket won two 2026 Reppy Awards from RepVue, ranking in the top 5% of all sales orgs. AE Alexandra Lister shares what it's like to grow a sales career here.

Security News
NIST will stop enriching most CVEs under a new risk-based model, narrowing the NVD's scope as vulnerability submissions continue to surge.

Company News
/Security News
Socket is an initial recipient of OpenAI's Cybersecurity Grant Program, which commits $10M in API credits to defenders securing open source software.