Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add: optimized get token balances #104

Merged
merged 11 commits into from
Oct 18, 2023
13 changes: 10 additions & 3 deletions core/definitions/src/platform.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,8 @@ import { NativeAddress } from "./address";
import { WormholeMessageId } from "./attestation";
import { ChainContext } from "./chain";
import { RpcConnection } from "./rpc";
import { ChainsConfig, SignedTx, TokenId, TxHash } from "./types";
import { AnyAddress, Balances, ChainsConfig, TokenId, TxHash } from "./types";
import { SignedTx } from "./types";
import { UniversalAddress } from "./universalAddress";

export interface PlatformUtils<P extends PlatformName> {
Expand All @@ -21,14 +22,20 @@ export interface PlatformUtils<P extends PlatformName> {
getDecimals(
chain: ChainName,
rpc: RpcConnection<P>,
token: NativeAddress<P> | UniversalAddress | "native",
token: AnyAddress | "native",
): Promise<bigint>;
getBalance(
chain: ChainName,
rpc: RpcConnection<P>,
walletAddr: string,
token: NativeAddress<P> | UniversalAddress | "native",
token: AnyAddress,
): Promise<bigint | null>;
getBalances(
chain: ChainName,
rpc: RpcConnection<P>,
walletAddress: string,
tokens: AnyAddress[],
): Promise<Balances>;
getCurrentBlock(rpc: RpcConnection<P>): Promise<number>;

// Platform interaction utils
Expand Down
10 changes: 5 additions & 5 deletions core/definitions/src/protocols/cctp.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,12 @@ import {
deserializeLayout,
uint8ArrayToHexByteString,
} from "@wormhole-foundation/sdk-base";
import { ChainAddress, UniversalOrNative } from "../address";
import { ChainAddress } from "../address";
import { CircleMessageId } from "../attestation";
import { universalAddressItem } from "../layout-items";
import "../payloads/connect";
import { RpcConnection } from "../rpc";
import { TokenId } from "../types";
import { AnyAddress, TokenId } from "../types";
import { UnsignedTransaction } from "../unsignedTransaction";
import { keccak256 } from "../utils";

Expand Down Expand Up @@ -55,7 +55,7 @@ export type CircleTransferMessage = {
export interface AutomaticCircleBridge<P extends PlatformName> {
transfer(
token: ChainAddress,
sender: UniversalOrNative<P>,
sender: AnyAddress,
recipient: ChainAddress,
amount: bigint,
nativeGas?: bigint,
Expand All @@ -66,13 +66,13 @@ export interface AutomaticCircleBridge<P extends PlatformName> {
// https://github.com/circlefin/evm-cctp-contracts
export interface CircleBridge<P extends PlatformName> {
redeem(
sender: UniversalOrNative<P>,
sender: AnyAddress,
message: string,
attestation: string,
): AsyncGenerator<UnsignedTransaction>;
transfer(
token: ChainAddress,
sender: UniversalOrNative<P>,
sender: AnyAddress,
recipient: ChainAddress,
amount: bigint,
): AsyncGenerator<UnsignedTransaction>;
Expand Down
4 changes: 2 additions & 2 deletions core/definitions/src/protocols/core.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { PlatformName } from "@wormhole-foundation/sdk-base";
import { UniversalOrNative } from "../address";
import { AnyAddress } from "../types";
import { UnsignedTransaction } from "../unsignedTransaction";
import { RpcConnection } from "../rpc";

Expand All @@ -15,7 +15,7 @@ export function supportsWormholeCore<P extends PlatformName>(

export interface WormholeCore<P extends PlatformName> {
publishMessage(
sender: UniversalOrNative<P>,
sender: AnyAddress,
message: string | Uint8Array
): AsyncGenerator<UnsignedTransaction>;
// TODO: parseTransactionDetails
Expand Down
8 changes: 4 additions & 4 deletions core/definitions/src/protocols/ibc.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,10 @@ import {
PlatformName,
toChainId,
} from "@wormhole-foundation/sdk-base";
import { ChainAddress, NativeAddress, UniversalOrNative } from "../address";
import { ChainAddress, NativeAddress } from "../address";
import { IbcMessageId, WormholeMessageId } from "../attestation";
import { RpcConnection } from "../rpc";
import { TokenId, TxHash } from "../types";
import { AnyAddress, TokenId, TxHash } from "../types";
import { UnsignedTransaction } from "../unsignedTransaction";

// Configuration for a transfer through the Gateway
Expand Down Expand Up @@ -209,9 +209,9 @@ export function supportsIbcBridge<P extends PlatformName>(
export interface IbcBridge<P extends PlatformName> {
//alternative naming: initiateTransfer
transfer(
sender: UniversalOrNative<P>,
sender: AnyAddress,
recipient: ChainAddress,
token: UniversalOrNative<P> | "native",
token: AnyAddress | "native",
amount: bigint,
payload?: Uint8Array,
): AsyncGenerator<UnsignedTransaction>;
Expand Down
26 changes: 13 additions & 13 deletions core/definitions/src/protocols/tokenBridge.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { PlatformName } from "@wormhole-foundation/sdk-base";
import { UniversalOrNative, NativeAddress, ChainAddress } from "../address";
import { TokenId } from "../types";
import { NativeAddress, ChainAddress } from "../address";
import { AnyAddress, TokenId } from "../types";
import { VAA } from "../vaa";
import { UnsignedTransaction } from "../unsignedTransaction";
import "../payloads/tokenBridge";
Expand Down Expand Up @@ -36,9 +36,9 @@ export function supportsAutomaticTokenBridge<P extends PlatformName>(

export interface TokenBridge<P extends PlatformName> {
// checks a native address to see if its a wrapped version
isWrappedAsset(nativeAddress: UniversalOrNative<P>): Promise<boolean>;
isWrappedAsset(nativeAddress: AnyAddress): Promise<boolean>;
// returns the original asset with its foreign chain
getOriginalAsset(nativeAddress: UniversalOrNative<P>): Promise<TokenId>;
getOriginalAsset(nativeAddress: AnyAddress): Promise<TokenId>;
// returns the wrapped version of the native asset
getWrappedNative(): Promise<NativeAddress<P>>;

Expand All @@ -53,24 +53,24 @@ export interface TokenBridge<P extends PlatformName> {
): Promise<boolean>;
//signer required:
createAttestation(
token_to_attest: UniversalOrNative<P>,
payer?: UniversalOrNative<P>
token_to_attest: AnyAddress,
payer?: AnyAddress
): AsyncGenerator<UnsignedTransaction>;
submitAttestation(
vaa: VAA<"AttestMeta">,
payer?: UniversalOrNative<P>
payer?: AnyAddress
): AsyncGenerator<UnsignedTransaction>;
//alternative naming: initiateTransfer
transfer(
sender: UniversalOrNative<P>,
sender: AnyAddress,
recipient: ChainAddress,
token: UniversalOrNative<P> | "native",
token: AnyAddress | "native",
amount: bigint,
payload?: Uint8Array
): AsyncGenerator<UnsignedTransaction>;
//alternative naming: completeTransfer
redeem(
sender: UniversalOrNative<P>,
sender: AnyAddress,
vaa: VAA<"Transfer"> | VAA<"TransferWithPayload">,
unwrapNative?: boolean //default: true
): AsyncGenerator<UnsignedTransaction>;
Expand All @@ -79,15 +79,15 @@ export interface TokenBridge<P extends PlatformName> {

export interface AutomaticTokenBridge<P extends PlatformName> {
transfer(
sender: UniversalOrNative<P>,
sender: AnyAddress,
recipient: ChainAddress,
token: UniversalOrNative<P> | "native",
token: AnyAddress | "native",
amount: bigint,
relayerFee: bigint,
nativeGas?: bigint
): AsyncGenerator<UnsignedTransaction>;
redeem(
sender: UniversalOrNative<P>,
sender: AnyAddress,
vaa: VAA<"TransferWithPayload">
): AsyncGenerator<UnsignedTransaction>;
getRelayerFee(
Expand Down
10 changes: 5 additions & 5 deletions core/definitions/src/relayer.ts
Original file line number Diff line number Diff line change
@@ -1,19 +1,19 @@
import { Chain, PlatformName } from "@wormhole-foundation/sdk-base";
import { UniversalOrNative } from "./address";
import { AnyAddress } from "./types";

export interface Relayer<P extends PlatformName> {
relaySupported(chain: Chain): boolean;
getRelayerFee(
sourceChain: Chain,
destChain: Chain,
tokenId: UniversalOrNative<P>,
tokenId: AnyAddress,
): Promise<bigint>;
// TODO: What should this be named?
// I don't think it should return an UnisgnedTransaction
// rather it should take some signing callbacks and
// a ref to track the progress
startTransferWithRelay(
token: UniversalOrNative<P> | "native",
token: AnyAddress | "native",
amount: bigint,
toNativeToken: string,
sendingChain: Chain,
Expand All @@ -24,13 +24,13 @@ export interface Relayer<P extends PlatformName> {
): Promise<any>;
calculateNativeTokenAmt(
destChain: Chain,
tokenId: UniversalOrNative<P>,
tokenId: AnyAddress,
amount: bigint,
walletAddress: string,
): Promise<bigint>;
calculateMaxSwapAmount(
destChain: Chain,
tokenId: UniversalOrNative<P>,
tokenId: AnyAddress,
walletAddress: string,
): Promise<bigint>;
}
Expand Down
11 changes: 11 additions & 0 deletions core/definitions/src/testing/mocks/platform.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,8 @@ import {
nativeIsRegistered,
NativeAddress,
UniversalAddress,
AnyAddress,
Balances,
} from "../..";
import { MockRpc } from "./rpc";
import { MockChain } from "./chain";
Expand Down Expand Up @@ -84,6 +86,15 @@ export class MockPlatform<P extends PlatformName> implements Platform<P> {
throw new Error("Method not implemented.");
}

getBalances(
chain: ChainName,
rpc: RpcConnection<PlatformName>,
walletAddress: string,
tokens: AnyAddress[],
): Promise<Balances> {
throw new Error("method not implemented");
}

getChain(chain: ChainName): ChainContext<P> {
if (chain in this.conf) return new MockChain<P>(this.conf[chain]!);
throw new Error("No configuration available for chain: " + chain);
Expand Down
17 changes: 7 additions & 10 deletions core/definitions/src/testing/mocks/tokenBridge.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,10 @@
import { PlatformName } from "@wormhole-foundation/sdk-base";
import {
AnyAddress,
ChainAddress,
NativeAddress,
RpcConnection,
TokenBridge,
TokenId,
UniversalOrNative,
UnsignedTransaction,
VAA,
} from "../..";
Expand All @@ -19,10 +18,10 @@ import {
export class MockTokenBridge<P extends PlatformName> implements TokenBridge<P> {
constructor(readonly rpc: RpcConnection<P>) {}

isWrappedAsset(token: UniversalOrNative<P>): Promise<boolean> {
isWrappedAsset(token: AnyAddress): Promise<boolean> {
throw new Error("Method not implemented.");
}
getOriginalAsset(token: UniversalOrNative<P>): Promise<ChainAddress> {
getOriginalAsset(token: AnyAddress): Promise<ChainAddress> {
throw new Error("Method not implemented.");
}
hasWrappedAsset(original: ChainAddress): Promise<boolean> {
Expand All @@ -36,9 +35,7 @@ export class MockTokenBridge<P extends PlatformName> implements TokenBridge<P> {
): Promise<boolean> {
throw new Error("Method not implemented.");
}
createAttestation(
address: UniversalOrNative<P>,
): AsyncGenerator<UnsignedTransaction> {
createAttestation(address: AnyAddress): AsyncGenerator<UnsignedTransaction> {
throw new Error("Method not implemented.");
}
submitAttestation(
Expand All @@ -47,16 +44,16 @@ export class MockTokenBridge<P extends PlatformName> implements TokenBridge<P> {
throw new Error("Method not implemented.");
}
transfer(
sender: UniversalOrNative<P>,
sender: AnyAddress,
recipient: ChainAddress,
token: "native" | UniversalOrNative<P>,
token: "native" | AnyAddress,
anondev2323 marked this conversation as resolved.
Show resolved Hide resolved
amount: bigint,
payload?: Uint8Array | undefined,
): AsyncGenerator<UnsignedTransaction> {
throw new Error("Method not implemented.");
}
redeem(
sender: UniversalOrNative<P>,
sender: AnyAddress,
vaa: VAA<"Transfer"> | VAA<"TransferWithPayload">,
unwrapNative?: boolean | undefined,
): AsyncGenerator<UnsignedTransaction> {
Expand Down
14 changes: 14 additions & 0 deletions core/definitions/src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,16 @@ export type SequenceId = bigint;

export type SignedTx = any;

// TODO: Can we make this more dynamic?
barnjamin marked this conversation as resolved.
Show resolved Hide resolved
export type AnyAddress =
| NativeAddress<PlatformName>
| UniversalAddress
| string
| number
| Uint8Array
| number[]
| "native";

export type TokenId = ChainAddress;
export function isTokenId(thing: TokenId | any): thing is TokenId {
return (
Expand All @@ -23,6 +33,10 @@ export function isTokenId(thing: TokenId | any): thing is TokenId {
);
}

export type Balances = {
[key: string]: BigInt | null;
};

export interface Signer {
chain(): ChainName;
address(): string;
Expand Down
7 changes: 6 additions & 1 deletion core/definitions/src/universalAddress.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import { Address, NativeAddress, toNative } from "./address";

export class UniversalAddress implements Address {
static readonly byteSize = 32;
private readonly type = 'Universal';

private readonly address: Uint8Array;

Expand Down Expand Up @@ -45,7 +46,7 @@ export class UniversalAddress implements Address {
}

equals(other: UniversalAddress): boolean {
if (other instanceof UniversalAddress) {
if (UniversalAddress.instanceof(other)) {
return other.toString() === this.toString();
}
return false;
Expand All @@ -54,4 +55,8 @@ export class UniversalAddress implements Address {
static isValidAddress(address: string) {
return isHexByteString(address, UniversalAddress.byteSize);
}

static instanceof(address: any) {
return address.type === 'Universal';
}
}
2 changes: 0 additions & 2 deletions platforms/cosmwasm/__tests__/unit/platform.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,6 @@ import { expect, test } from "@jest/globals";
import {
chains,
chainConfigs,
DEFAULT_NETWORK,
chainToPlatform,
} from "@wormhole-foundation/connect-sdk";
import { CosmwasmPlatform } from "../../src/platform";

Expand Down
Loading