Skip to content

Commit

Permalink
simulate extension for fee granter param
Browse files Browse the repository at this point in the history
  • Loading branch information
BurntVal committed Dec 4, 2024
1 parent 683a738 commit 74cc6a8
Show file tree
Hide file tree
Showing 3 changed files with 6,701 additions and 5,438 deletions.
1 change: 1 addition & 0 deletions packages/abstraxion-core/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@
"@cosmjs/cosmwasm-stargate": "^0.32.4",
"@cosmjs/crypto": "^0.32.4",
"@cosmjs/encoding": "^0.32.4",
"@cosmjs/math": "^0.32.4",
"@cosmjs/proto-signing": "^0.32.4",
"@cosmjs/stargate": "^0.32.4",
"@cosmjs/tendermint-rpc": "^0.32.4",
Expand Down
89 changes: 86 additions & 3 deletions packages/abstraxion-core/src/GranteeSignerClient.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import { customAccountFromAny } from "@burnt-labs/signers";
import {
DeliverTxResponse,
SigningCosmWasmClient,
Expand All @@ -6,23 +7,31 @@ import {
import {
AccountData,
EncodeObject,
encodePubkey,
OfflineSigner,
} from "@cosmjs/proto-signing";
import {
calculateFee,
createProtobufRpcClient,
GasPrice,
type Account,
type SignerData,
type StdFee,
} from "@cosmjs/stargate";
import { TxRaw } from "cosmjs-types/cosmos/tx/v1beta1/tx";
import { AuthInfo, Fee, TxRaw } from "cosmjs-types/cosmos/tx/v1beta1/tx";
import { MsgExec } from "cosmjs-types/cosmos/authz/v1beta1/tx";
import {
HttpEndpoint,
Tendermint37Client,
TendermintClient,
} from "@cosmjs/tendermint-rpc";
import { customAccountFromAny } from "@burnt-labs/signers";
import { Uint53 } from "@cosmjs/math";
import { encodeSecp256k1Pubkey } from "@cosmjs/amino";
import {
ServiceClientImpl,
SimulateRequest,
} from "cosmjs-types/cosmos/tx/v1beta1/service";
import { SignMode } from "cosmjs-types/cosmos/tx/signing/v1beta1/signing";

export interface GranteeSignerOptions {
readonly granterAddress: string;
Expand Down Expand Up @@ -104,6 +113,75 @@ export class GranteeSignerClient extends SigningCosmWasmClient {
return customAccountFromAny(account);
}

public async simulate(
signerAddress: string,
messages: readonly EncodeObject[],
memo: string | undefined,
feeGranter?: string,
): Promise<number> {
const { sequence } = await this.getSequence(signerAddress);
const accountFromSigner = (await this._signer.getAccounts()).find(
(account) => account.address === signerAddress,
);

if (!accountFromSigner) {
throw new Error("No account found.");
}

const pubkey = encodeSecp256k1Pubkey(accountFromSigner.pubkey);

const queryClient = this.getQueryClient();
if (!queryClient) {
throw new Error("Couldn't get query client");
}

const rpc = createProtobufRpcClient(queryClient);
const queryService = new ServiceClientImpl(rpc);

const authInfo = AuthInfo.fromPartial({
fee: Fee.fromPartial({ granter: feeGranter }),
signerInfos: [
{
publicKey: encodePubkey(pubkey),
modeInfo: {
single: {
mode: SignMode.SIGN_MODE_DIRECT,
},
},
sequence: BigInt(sequence),
},
],
});
const authInfoBytes = AuthInfo.encode(authInfo).finish();

const txBodyEncodeObject = {
typeUrl: "/cosmos.tx.v1beta1.TxBody",
value: {
messages: messages,
memo: memo,
},
};
const bodyBytes = this.registry.encode(txBodyEncodeObject);

const tx = TxRaw.fromPartial({
bodyBytes,
authInfoBytes,
signatures: [new Uint8Array([10])],
});

const request = SimulateRequest.fromPartial({
txBytes: TxRaw.encode(tx).finish(),
});

const { gasInfo } = await queryService.Simulate(request);

if (!gasInfo) {
throw new Error("No gas info returned");
}

return Uint53.fromString(gasInfo.gasUsed.toString()).toNumber();
}

public async signAndBroadcast(
signerAddress: string,
messages: readonly EncodeObject[],
Expand Down Expand Up @@ -135,7 +213,12 @@ export class GranteeSignerClient extends SigningCosmWasmClient {
"Gas price must be set in the client options when auto gas is used",
);
}
const gasEstimation = await this.simulate(signerAddress, messages, memo);
const gasEstimation = await this.simulate(
signerAddress,
messages,
memo,
granter,
);
const multiplier =
typeof fee == "number" ? fee : this._defaultGasMultiplier;
const calculatedFee = calculateFee(
Expand Down
Loading

0 comments on commit 74cc6a8

Please sign in to comment.