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

env/devnet-amplifier #472

Open
wants to merge 47 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
47 commits
Select commit Hold shift + click to select a range
6169188
chore: account session hooks
SGiaccobasso Oct 7, 2024
cce10e4
chore: refactor use custom useAccount and useDisconnect everywhere
SGiaccobasso Oct 8, 2024
9c59557
chore: next-auth session
SGiaccobasso Oct 9, 2024
ee38d40
chore: merge main
SGiaccobasso Oct 9, 2024
3b88349
chore: useEffect to fix interactivity issue
SGiaccobasso Oct 10, 2024
e86fac1
chore: interactivity issue
SGiaccobasso Oct 10, 2024
60d62de
chore: fix session issue
SGiaccobasso Oct 10, 2024
d51a336
chore: add sui logo
SGiaccobasso Oct 10, 2024
167a7f3
chore: fix login modal
SGiaccobasso Oct 10, 2024
f7e5da6
chore: fix main page style issue
SGiaccobasso Oct 10, 2024
0d9307c
chore: useChainId custom hook refactor
SGiaccobasso Oct 14, 2024
9ed314f
chore: useBalance refactor
SGiaccobasso Oct 14, 2024
9f73393
chore: lockfile update
SGiaccobasso Oct 14, 2024
7436461
chore: wip useSwitchChain
SGiaccobasso Oct 23, 2024
c432834
chore: wip deploy token sui
SGiaccobasso Oct 25, 2024
6a94acc
chore: return undefined chain if no wallet connected in useAccount
SGiaccobasso Oct 29, 2024
30f4915
chore: sign and execute deploy tx
SGiaccobasso Oct 29, 2024
4400e78
chore: all sui deploy token txs working
SGiaccobasso Oct 30, 2024
c8fcf4a
chore: db migration to accept sui types
SGiaccobasso Nov 6, 2024
9599020
chore: register deployed token in db
SGiaccobasso Nov 19, 2024
96553d7
chore: testing remote deploy
SGiaccobasso Nov 25, 2024
f51a3ca
Feat/sui integration euro (#470)
SGiaccobasso Nov 27, 2024
ae5e8b8
chore: prevent error after deploying remote token
SGiaccobasso Nov 28, 2024
1677d4b
feat: support deployment from sui to evm (#471)
npty Nov 28, 2024
bbc5c4b
chore: use contract addresses from env file
SGiaccobasso Nov 28, 2024
4034723
chore: sui client to use env network
SGiaccobasso Nov 28, 2024
0b65bd3
chore: remove logs
SGiaccobasso Nov 28, 2024
8593f94
feat: support devnet amplifier (#473)
npty Dec 2, 2024
135ab42
chore: wip token details
SGiaccobasso Dec 10, 2024
df15fbe
chore: add minting initial supply to sui
SGiaccobasso Dec 15, 2024
9c6db01
chore: update sui token decimals (#475)
npty Dec 17, 2024
e355409
fix: build devnet amplifier (#477)
npty Dec 19, 2024
43ffad3
chore: fetching token data (#478)
SGiaccobasso Dec 19, 2024
6b8cacb
chore: connect button style
SGiaccobasso Dec 19, 2024
2f2f0c9
fix: use deploy token (#479)
npty Dec 20, 2024
6fe339c
feat: integrate estimate gas fee api (#480)
npty Dec 23, 2024
f7be8d3
chore: remove address restriction
SGiaccobasso Jan 20, 2025
8105c9f
chore: upgraded contracts and flow support part 1
SGiaccobasso Jan 20, 2025
1c8c84a
chore: upgraded contracts and flow support part 1
SGiaccobasso Jan 20, 2025
87c161a
chore: upgraded contracts and flow support part 1
SGiaccobasso Jan 20, 2025
a11b924
chore: upgraded contracts and flow support part 3
SGiaccobasso Jan 20, 2025
bb4b9d5
chore: upgraded contracts and flow support part 4
SGiaccobasso Jan 20, 2025
b466200
chore: upgraded contracts and flow support part 5
SGiaccobasso Jan 20, 2025
10a8d5a
chore: upgraded contracts and flow support part 7
SGiaccobasso Jan 20, 2025
3c29149
chore: upgraded contracts and flow support part 8
SGiaccobasso Jan 20, 2025
f6ad38e
chore: upgraded contracts and flow support part 9
SGiaccobasso Jan 20, 2025
ea327c8
chore: remove hardcoded sui chain
SGiaccobasso Jan 21, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions apps/maestro/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -34,13 +34,17 @@
"release": "tsx scripts/release.ts"
},
"dependencies": {
"@axelar-network/axelar-cgp-sui": "0.0.0-snapshot.424bc13",
"@axelar-network/axelarjs-sdk": "0.17.1-alpha.12",
"@axelarjs/api": "workspace:*",
"@axelarjs/core": "workspace:*",
"@axelarjs/evm": "workspace:*",
"@axelarjs/ui": "workspace:*",
"@axelarjs/utils": "workspace:*",
"@hookform/resolvers": "^3.3.4",
"@mysten/bcs": "^1.1.0",
"@mysten/dapp-kit": "^0.14.43",
"@mysten/sui": "^1.11.0",
"@sentry/nextjs": "^7.108.0",
"@tanstack/react-query": "^5.28.6",
"@trpc/client": "11.0.0-next.320",
Expand All @@ -51,6 +55,7 @@
"@vercel/postgres": "^0.7.2",
"@web3modal/wagmi": "^4.1.1",
"drizzle-orm": "^0.29.5",
"hardhat": "^2.22.13",
"lucide-react": "^0.265.0",
"next": "^14.1.4",
"nextjs-cors": "^2.2.0",
Expand Down
3 changes: 3 additions & 0 deletions apps/maestro/public/logos/chains/sui.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
2 changes: 1 addition & 1 deletion apps/maestro/src/config/env.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ export const NEXT_PUBLIC_WALLET_CONNECT_PROJECT_ID = Maybe.of(

export const NEXT_PUBLIC_NETWORK_ENV = String(
process.env.NEXT_PUBLIC_NETWORK_ENV ?? "testnet"
) as "mainnet" | "testnet";
) as "mainnet" | "testnet" | "devnet-amplifier";

export const NEXT_PUBLIC_AXELAR_CONFIGS_URL = Maybe.of(
process.env.NEXT_PUBLIC_AXELAR_CONFIGS_URL
Expand Down
90 changes: 87 additions & 3 deletions apps/maestro/src/config/evm-chains.ts
Original file line number Diff line number Diff line change
Expand Up @@ -51,11 +51,12 @@ import { NEXT_PUBLIC_NETWORK_ENV } from "./env";
export interface ExtendedWagmiChainConfig extends Chain {
axelarChainId: string;
axelarChainName: string;
environment: "mainnet" | "testnet";
environment: "mainnet" | "testnet" | "devnet-amplifier";
}

const ENVIRONMENTS = {
mainnet: "mainnet",
devnet: "devnet-amplifier",
testnet: "testnet",
} as const;

Expand All @@ -78,11 +79,70 @@ export const ALL_CHAINS: ExtendedWagmiChainConfig[] = [
axelarChainName: "ethereum",
environment: ENVIRONMENTS.mainnet,
},
// TODO: correct this
{
id: 101,
axelarChainId: "sui",
axelarChainName: "sui",
environment: ENVIRONMENTS.mainnet,
name: "Sui",
nativeCurrency: {
name: "SUI",
symbol: "SUI",
decimals: 9,
},
rpcUrls: {
default: { http: ["https://sui-rpc.publicnode.com"] },
public: { http: ["https://sui-rpc.publicnode.com"] },
},
blockExplorers: {
default: { name: "Sui Explorer", url: "https://suiexplorer.com/" },
},
},
{
id: 103,
axelarChainId: "sui",
axelarChainName: "sui",
environment: ENVIRONMENTS.devnet,
name: "Sui Testnet",
nativeCurrency: {
name: "SUI",
symbol: "SUI",
decimals: 9,
},
rpcUrls: {
default: { http: ["https://fullnode.testnet.sui.io:443"] },
public: { http: ["https://fullnode.testnet.sui.io:443"] },
},
blockExplorers: {
default: { name: "Sui Explorer", url: "https://suiscan.xyz/testnet" },
},
},
//TODO: check if this is ok
{
id: 103,
axelarChainId: "sui",
axelarChainName: "sui",
environment: ENVIRONMENTS.testnet,
name: "Sui Testnet",
nativeCurrency: {
name: "SUI",
symbol: "SUI",
decimals: 9,
},
rpcUrls: {
default: { http: ["https://fullnode.testnet.sui.io:443"] },
public: { http: ["https://fullnode.testnet.sui.io:443"] },
},
blockExplorers: {
default: { name: "Sui Explorer", url: "https://suiscan.xyz/testnet" },
},
},
{
...sepolia,
rpcUrls: {
default: { http: ["https://endpoints.omniatech.io/v1/eth/sepolia/public", "https://1rpc.io/sepolia"] }, // Temporarily using this url
public: { http: ["https://endpoints.omniatech.io/v1/eth/sepolia/public", "https://1rpc.io/sepolia"] },
default: { http: ["https://rpc-sepolia.rockx.com"] },
public: { http: ["https://rpc-sepolia.rockx.com"] },
},
axelarChainId: "ethereum-sepolia",
axelarChainName: "ethereum-sepolia",
Expand Down Expand Up @@ -366,6 +426,30 @@ export const ALL_CHAINS: ExtendedWagmiChainConfig[] = [
axelarChainName: "blast-sepolia",
environment: ENVIRONMENTS.testnet,
},
{
...blastSepolia,
axelarChainId: "blast-sepolia",
axelarChainName: "blast-sepolia",
environment: ENVIRONMENTS.testnet,
},
{
...avalancheFuji,
axelarChainId: "avalanche-fuji",
axelarChainName: "avalanche-fuji",
environment: ENVIRONMENTS.devnet,
},
{
...optimismSepolia,
axelarChainId: "optimism-sepolia",
axelarChainName: "optimism-sepolia",
environment: ENVIRONMENTS.devnet,
},
{
...sepolia,
axelarChainId: "eth-sepolia",
axelarChainName: "eth-sepolia",
environment: ENVIRONMENTS.devnet,
},
] as const;

export const WAGMI_CHAIN_CONFIGS = ALL_CHAINS.filter(
Expand Down
37 changes: 23 additions & 14 deletions apps/maestro/src/config/next-auth.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,9 @@ import { Maybe } from "@axelarjs/utils";
import type { NextAuthOptions } from "next-auth";
import CredentialsProvider from "next-auth/providers/credentials";

import { verifyPersonalMessageSignature } from "@mysten/sui/verify";
import { kv } from "@vercel/kv";
import { getAddress, verifyMessage } from "viem";
import { verifyMessage } from "viem";

import db from "~/lib/drizzle/client";
import { getSignInMessage } from "~/server/routers/auth/createSignInMessage";
Expand Down Expand Up @@ -43,15 +44,14 @@ export const NEXT_AUTH_OPTIONS: NextAuthOptions = {
async authorize(credentials, req) {
if (
!credentials?.address ||
!getAddress(credentials?.address) ||
// !getAddress(credentials?.address) ||
!credentials?.signature
) {
return null;
}

const address = getAddress(credentials.address);
//TODO: revert
const address = credentials.address as `0x${string}`;
const signature = credentials.signature as `0x${string}`;

const [accountNonce, accountStatus] = await Promise.all([
kvClient.getAccountNonce(address),
kvClient.getAccountStatus(address),
Expand Down Expand Up @@ -79,21 +79,30 @@ export const NEXT_AUTH_OPTIONS: NextAuthOptions = {
}
return null;
}

let isMessageSigned;
const message = getSignInMessage(accountNonce ?? 0);

const isMessageSigned = await verifyMessage({
message,
signature,
address,
});
// is SUI address
if (address.length === 66) {
const suiPublicKey = await verifyPersonalMessageSignature(
new TextEncoder().encode(message),
signature
);
isMessageSigned = suiPublicKey.toSuiAddress() === address;
}
// is EVM address
else if (address.length === 42) {
isMessageSigned = await verifyMessage({
message,
signature,
address,
});
}

if (!isMessageSigned) {
return null;
}

// increment nonce

await kvClient.incrementAccountNonce(address);

return {
Expand All @@ -110,7 +119,7 @@ export const NEXT_AUTH_OPTIONS: NextAuthOptions = {
},
callbacks: {
async session({ session, token }) {
const address = getAddress(token.sub ?? "");
const address = token.sub as `0x${string}`;

session.address = address;
session.accountStatus = await kvClient
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,12 +14,12 @@ export type DeployAndRegisterTransactionState =
}
| {
type: "deploying";
txHash: `0x${string}`;
txHash: string;
}
| {
type: "deployed";
txHash: `0x${string}`;
tokenAddress: `0x${string}`;
txHash: string;
tokenAddress: string;
};

export const INITIAL_STATE = {
Expand All @@ -28,11 +28,11 @@ export const INITIAL_STATE = {
tokenName: "",
tokenSymbol: "",
tokenDecimals: 18,
tokenAddress: "0x" as `0x${string}`,
tokenAddress: "0x",
},
txState: { type: "idle" } as DeployAndRegisterTransactionState,
selectedChains: [] as string[],
onDeployTxHash: (txHash: `0x${string}`) => {
onDeployTxHash: (txHash: string) => {
logger.log("onDeployTxHash", txHash);
},
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { useCallback, useEffect, useMemo, useState } from "react";

import { reduce } from "rambda";
import type { TransactionReceipt } from "viem";
import { useAccount, useChainId, useWaitForTransactionReceipt } from "wagmi";
import { useWaitForTransactionReceipt } from "wagmi";

import {
useReadInterchainTokenFactoryCanonicalInterchainTokenId,
Expand All @@ -15,6 +15,7 @@ import {
decodeDeploymentMessageId,
type DeploymentMessageId,
} from "~/lib/drizzle/schema";
import { useAccount, useChainId } from "~/lib/hooks";
import { trpc } from "~/lib/trpc";
import { isValidEVMAddress } from "~/lib/utils/validation";
import { RecordInterchainTokenDeploymentInput } from "~/server/routers/interchainToken/recordInterchainTokenDeployment";
Expand All @@ -25,7 +26,7 @@ export interface UseDeployAndRegisterCanonicalTokenInput {
sourceChainId: string;
tokenName: string;
tokenSymbol: string;
tokenAddress: `0x${string}`;
tokenAddress: string;
decimals: number;
destinationChainIds: string[];
remoteDeploymentGasFees: bigint[];
Expand Down Expand Up @@ -92,7 +93,7 @@ export function useDeployAndRegisterRemoteCanonicalTokenMutation(

const deployTxData =
INTERCHAIN_TOKEN_FACTORY_ENCODERS.registerCanonicalInterchainToken.data({
tokenAddress: input.tokenAddress,
tokenAddress: input.tokenAddress as `0x${string}`,
});

if (!input.destinationChainIds.length) {
Expand All @@ -105,7 +106,7 @@ export function useDeployAndRegisterRemoteCanonicalTokenMutation(

const args = {
originalChain: originalChainName,
originalTokenAddress: input.tokenAddress,
originalTokenAddress: input.tokenAddress as `0x${string}`,
destinationChain,
gasValue,
};
Expand Down Expand Up @@ -165,6 +166,7 @@ export function useDeployAndRegisterRemoteCanonicalTokenMutation(
tokenSymbol: input.tokenSymbol,
tokenDecimals: input.decimals,
axelarChainId: input.sourceChainId,
tokenManagerAddress: "",
destinationAxelarChainIds: input.destinationChainIds,
});
},
Expand Down Expand Up @@ -194,7 +196,7 @@ export function useDeployAndRegisterRemoteCanonicalTokenMutation(
onStatusUpdate({
type: "deployed",
tokenAddress: recordDeploymentArgs.tokenAddress as `0x${string}`,
txHash: tx.hash,
txHash: tx.hash as `0x${string}`,
});
})
.catch((e) => {
Expand Down Expand Up @@ -225,6 +227,7 @@ export function useDeployAndRegisterRemoteCanonicalTokenMutation(
tokenDecimals: input.decimals,
axelarChainId: input.sourceChainId,
tokenAddress: input.tokenAddress,
tokenManagerAddress: "",
destinationAxelarChainIds: input.destinationChainIds,
deploymentMessageId: "",
});
Expand Down
Loading
Loading