From d922b2babace7ef6e05855d666450ce65113c28a Mon Sep 17 00:00:00 2001 From: BarryTong65 Date: Tue, 15 Oct 2024 17:36:39 +0800 Subject: [PATCH] feat: support user agent header --- src/paymasterclient.ts | 55 +++++++++++++++++++++++++++++++++++------ tests/paymaster.spec.ts | 3 ++- tests/sponsor.spec.ts | 4 +-- 3 files changed, 51 insertions(+), 11 deletions(-) diff --git a/src/paymasterclient.ts b/src/paymasterclient.ts index 854e5a5..dbd9813 100644 --- a/src/paymasterclient.ts +++ b/src/paymasterclient.ts @@ -15,6 +15,7 @@ export type IsSponsorableOptions = { export type SendRawTransactionOptions = { PrivatePolicyUUID?: string + UserAgent?: string } export enum GaslessTransactionStatus { New = 0, Pending = 1, Confirmed = 2, Failed = 3, Invalid = 4} @@ -74,20 +75,58 @@ export class PaymasterClient { return await this.userClient.send('eth_chainId', []) } - async isSponsorable(tx: TransactionRequest, opts: IsSponsorableOptions = {} ): Promise { + async isSponsorable(tx: TransactionRequest, opts: IsSponsorableOptions = {}): Promise { if (opts.PrivatePolicyUUID) { - this.sponsorClient._getConnection().setHeader("X-MegaFuel-Policy-Uuid", opts.PrivatePolicyUUID) - return await this.sponsorClient.send('pm_isSponsorable', [tx]) + // Create a new provider with the updated header + const newConnection = this.sponsorClient._getConnection(); + newConnection.setHeader("X-MegaFuel-Policy-Uuid", opts.PrivatePolicyUUID); + + // Create a new provider with the modified connection + const sponsorProviderWithHeader = new ethers.JsonRpcProvider( + newConnection, + (this.sponsorClient as any)._network, + { + staticNetwork: (this.sponsorClient as any)._network, + batchMaxCount: (this.sponsorClient as any).batchMaxCount, + polling: (this.sponsorClient as any).polling + } + ); + + return await sponsorProviderWithHeader.send('pm_isSponsorable', [tx]); } - return await this.userClient.send('pm_isSponsorable', [tx]) + return await this.userClient.send('pm_isSponsorable', [tx]); } - async sendRawTransaction(signedTx: string, opts: SendRawTransactionOptions= {}): Promise { + async sendRawTransaction(signedTx: string, opts: SendRawTransactionOptions = {}): Promise { + let sponsorProvider = this.sponsorClient; + + if (opts.UserAgent || opts.PrivatePolicyUUID) { + // Create a new provider with the updated headers + const newConnection = this.sponsorClient._getConnection(); + + if (opts.UserAgent) { + newConnection.setHeader("User-Agent", opts.UserAgent); + } + if (opts.PrivatePolicyUUID) { + newConnection.setHeader("X-MegaFuel-Policy-Uuid", opts.PrivatePolicyUUID); + } + + // Create a new provider with the modified connection + sponsorProvider = new ethers.JsonRpcProvider( + newConnection, + (this.sponsorClient as any)._network, + { + staticNetwork: (this.sponsorClient as any)._network, + batchMaxCount: (this.sponsorClient as any).batchMaxCount, + polling: (this.sponsorClient as any).polling + } + ); + } + if (opts.PrivatePolicyUUID) { - this.sponsorClient._getConnection().setHeader("X-MegaFuel-Policy-Uuid", opts.PrivatePolicyUUID) - return await this.sponsorClient.send('eth_sendRawTransaction', [signedTx]) + return await sponsorProvider.send('eth_sendRawTransaction', [signedTx]); } - return await this.userClient.send('eth_sendRawTransaction', [signedTx]) + return await this.userClient.send('eth_sendRawTransaction', [signedTx]); } async getGaslessTransactionByHash(hash: string): Promise { diff --git a/tests/paymaster.spec.ts b/tests/paymaster.spec.ts index d32f7b5..5411a47 100644 --- a/tests/paymaster.spec.ts +++ b/tests/paymaster.spec.ts @@ -133,7 +133,8 @@ describe('paymasterQuery', () => { expect(res.Sponsorable).toEqual(true) const txOpt: SendRawTransactionOptions = { - PrivatePolicyUUID: PRIVATE_POLICY_UUID + PrivatePolicyUUID: PRIVATE_POLICY_UUID, + UserAgent: "TEST USER AGENT" }; const signedTx = await wallet.signTransaction(safeTransaction) diff --git a/tests/sponsor.spec.ts b/tests/sponsor.spec.ts index 33dfcba..5050a44 100644 --- a/tests/sponsor.spec.ts +++ b/tests/sponsor.spec.ts @@ -158,10 +158,10 @@ describe('sponsorQuery', () => { * Tests retrieving user spend data. */ describe('getUserSpendData', () => { - test('should return null for spend data when user has none', async () => { + test('should return not null for user spend data', async () => { const res = await sponsorClient.getUserSpendData(ACCOUNT_ADDRESS, POLICY_UUID) - expect(res).toBeNull() + expect(res).not.toBeNull() console.log('User spend data:', res) }) })