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

feat: multichain indexer ( part 1 ) #293

Merged
merged 12 commits into from
Aug 4, 2024
Original file line number Diff line number Diff line change
@@ -1,34 +1,20 @@
import { http, createPublicClient, PublicClient, createWalletClient } from 'viem'
import { sepolia } from 'viem/chains'
import { appenv } from '../config'
import { eosEvmTestnet } from 'app-env'

export const client: PublicClient = createPublicClient({
chain: eosEvmTestnet,
transport: http(),
})

export const walletClient = createWalletClient({
chain: eosEvmTestnet,
transport: http(),
key: appenv.evm.issuerKey,
account: appenv.evm.issuerAccount,
})

export const sepoliaClient: PublicClient = createPublicClient({
chain: {
...sepolia,
rpcUrls: {
default: {
http: [appenv.evm.sepoliaApi],
},
},
},
transport: http(),
})

export async function getCurrentBlockHeight() {
try {
const client = createPublicClient({
chain: eosEvmTestnet,
transport: http(),
})
const blockNumber = await client.getBlockNumber()
return blockNumber
} catch (error) {
Expand Down
8 changes: 6 additions & 2 deletions apps/indexer/src/lib/utils.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import fs from 'fs/promises'
import { erc20Abi } from 'abitype/abis'
import { client } from './evm-client'
import { Abi, Address, parseUnits } from 'viem'
import {Abi, Address, parseUnits, http, createPublicClient} from 'viem';
import {eosEvmTestnet} from 'app-env';

export async function writeToFile(data: string, filePath: string) {
try {
Expand Down Expand Up @@ -38,6 +38,10 @@ export function runPromisesInSeries<T>(
}

export async function getTokenDetails({ address }: { address: Address }) {
const client = createPublicClient({
chain: eosEvmTestnet,
transport: http(),
})
const results = await client.multicall({
contracts: [
{
Expand Down
12 changes: 8 additions & 4 deletions apps/indexer/src/modules/auction/auction-indexer.ts
Original file line number Diff line number Diff line change
@@ -1,21 +1,25 @@
import { Log, stringify } from 'viem'
import { client } from '~/lib/evm-client'
import {Log, stringify, http, createPublicClient} from 'viem';
import { TestnetEasyAuction } from 'app-contracts'
import {
bigintToPostgresTimestamp,
getEvents,
getTokenDetails,
runPromisesInSeries,
} from '~/lib/utils'
import { NewAuctionEvent, NewSellOrderEvent, NewUserEvent } from '~/modules/auction/auction.type'

import { NewAuctionEvent, NewSellOrderEvent, NewUserEvent } from './auction.type'
import BN from 'bn.js'
import { eosEvmTestnet } from 'app-env'
import { upsertAuctionDetail, upsertOrder } from '~/lib/supabase-client'

export async function startAuctionIndexer() {
console.log('indexing starting')

// TODO: create client for
const client = createPublicClient({
chain: eosEvmTestnet,
transport: http(),
})

// await writeToFile(stringify(TestnetEasyAuction.getEvents(), null, 2), './events.json')
// Get historical event logs
const blockNumber = await client.getBlockNumber()
Expand Down
9 changes: 7 additions & 2 deletions apps/indexer/src/modules/auction/easyauction.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,11 @@
import { getContract } from 'viem'
import { client } from '../../lib/evm-client'
import {getContract, http, createPublicClient} from 'viem';
import { TestnetEasyAuction } from 'app-contracts'
import {eosEvmTestnet} from 'app-env';

const client = createPublicClient({
chain: eosEvmTestnet,
transport: http(),
})

export const easyAuction = getContract({
...TestnetEasyAuction,
Expand Down
4 changes: 2 additions & 2 deletions apps/indexer/src/modules/presale/evm-contributions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { runPromisesInSeries } from '~/lib/utils'
import { Address, Log, PublicClient, createPublicClient, http, parseAbiItem, stringify } from 'viem'
import { TransferEvent } from '~/modules/auction/auction.type'
import { sepolia } from 'viem/chains'
import { smartsaleChains } from 'app-env'
import { appChains } from 'app-env'

const tokens: EVMTokenContractData[] = [SepoliaUSDT, TestnetUSDT]

Expand All @@ -14,7 +14,7 @@ export async function listenToEvmContributions() {
}

async function listenToEvmTransfersFn(token: EVMTokenContractData) {
const chain = smartsaleChains.dev.get(token.chainId)
const chain = appChains.dev.get(token.chainId)
if (!chain) return
console.log(`listening usdt transfers for token ${token.symbol} on chain ${chain.name}`)
const client: PublicClient = createPublicClient({
Expand Down
8 changes: 4 additions & 4 deletions apps/indexer/src/modules/swaps/evm-transfers.ts
Original file line number Diff line number Diff line change
@@ -1,20 +1,20 @@
import { EVMTokenContractData, SepoliaUSDT, TestnetUSDT } from 'app-contracts'
import { EVMTokenContractData, SepoliaUSDT, TestnetUSDT, appContracts } from 'app-contracts'
import { runPromisesInSeries } from '~/lib/utils'

import { Address, Log, PublicClient, createPublicClient, http, parseAbiItem, stringify } from 'viem'
import { TransferEvent } from '~/modules/auction/auction.type'
import { sepolia } from 'viem/chains'
import { smartsaleChains } from 'app-env'
import { appChains } from 'app-env'

const tokens: EVMTokenContractData[] = [SepoliaUSDT, TestnetUSDT]
const tokens: EVMTokenContractData[] = appContracts.dev.tokens.evm

export async function listenToEvmTransfers() {
console.log('subscribing to evm usdt transfers ...')
tokens.map(listenToEvmTransfersFn)
}

async function listenToEvmTransfersFn(token: EVMTokenContractData) {
const chain = smartsaleChains.dev.get(token.chainId)
const chain = appChains.dev.get(token.chainId)
if (!chain) return
console.log(`listening usdt transfers for token ${token.symbol} on chain ${chain.name}`)
const client: PublicClient = createPublicClient({
Expand Down
2 changes: 1 addition & 1 deletion apps/indexer/src/routes/healthcheck.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import express from 'express'
import { getCurrentBlockHeight } from '../lib/evm-client'
import { getCurrentBlockHeight } from '../lib/issuer-client'

export function startExpress() {
const app = express()
Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@
import { EVMContractData } from "../types";
import { sepolia } from "viem/chains";
import { EVMContractData } from "../../types";

export const TestnetAllowList: EVMContractData = {
address: "0x3D18904711fe451356eBA461B7747EA3Abff6c93",
indexFromBlock: 12241046,
chainId: 15557,
chainType: "evm",
chainName: "Sepolia",
chain: sepolia,
abi: [
{
inputs: [],
Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@
import { EVMContractData } from "../types";
import { sepolia } from "viem/chains";
import { EVMContractData } from "../../types";

export const TestnetDepositOrder: EVMContractData = {
address: "0x4faA684A1E0Cdd7cb271b5424a12A2D039624D78",
indexFromBlock: 12240840,
chainId: 15557,
chainType: "evm",
chainName: "EOS EVM Tesnet",
chain: sepolia,
abi: [
{
inputs: [
Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@
import { EVMContractData } from "../types";
import { sepolia } from "viem/chains";
import { EVMContractData } from "../../types";

export const TestnetEasyAuction: EVMContractData = {
address: "0x8d37219725eB0088360f744A5d894035D0f88F82",
indexFromBlock: 12239067,
chainId: 15557,
chainType: "evm",
chainName: "EOS EVM Tesnet",
chain: sepolia,
abi: [
{
inputs: [],
Expand Down
51 changes: 43 additions & 8 deletions packages/app-contracts/src/dev/index.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,43 @@
export * from "./testnet-easy-auction";
export * from "./testnet-deposit-order";
export * from "./testnet-usd-cred";
export * from "./testnet-mbots-prelaunch";
export * from "./sepolia-usdt";
export * from "./testnet-usdt";
export * from "./eos-fake-bitusd";
export * from "./eos-fake-usdt";
export * from "./auction/testnet-easy-auction";
export * from "./auction/testnet-deposit-order";
export * from "./tokens/testnet-usd-cred";
export * from "./tokens/testnet-mbots-prelaunch";
export * from "./tokens/sepolia-usdt";
export * from "./tokens/testnet-usdt";
export * from "./tokens/eos-fake-bitusd";
export * from "./tokens/eos-fake-usdt";

import { TestnetEasyAuction } from "./auction/testnet-easy-auction";
import { TestnetDepositOrder } from "./auction/testnet-deposit-order";
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

issue (complexity): Consider using dynamic imports and a single source of truth for all modules to simplify the code.

The new code introduces increased complexity due to the number of explicit imports and manual list management. This makes the file harder to maintain and scale. Consider using dynamic imports and a single source of truth for all modules to simplify the code. Here's a suggested refactor:

// Re-export all modules from their respective directories
export * from "./auction/testnet-easy-auction";
export * from "./auction/testnet-deposit-order";
export * from "./tokens/testnet-usd-cred";
export * from "./tokens/testnet-mbots-prelaunch";
export * from "./tokens/sepolia-usdt";
export * from "./tokens/testnet-usdt";
export * from "./tokens/eos-fake-bitusd";
export * from "./tokens/eos-fake-usdt";

// Import all modules dynamically
const modules = {
  auction: {
    TestnetEasyAuction: require("./auction/testnet-easy-auction").TestnetEasyAuction,
    TestnetDepositOrder: require("./auction/testnet-deposit-order").TestnetDepositOrder,
  },
  tokens: {
    TestnetUSDCred: require("./tokens/testnet-usd-cred").TestnetUSDCred,
    TestnetMBOTSPL: require("./tokens/testnet-mbots-prelaunch").TestnetMBOTSPL,
    SepoliaUSDT: require("./tokens/sepolia-usdt").SepoliaUSDT,
    TestnetUSDT: require("./tokens/testnet-usdt").TestnetUSDT,
    EOSFakeBITUSD: require("./tokens/eos-fake-bitusd").EOSFakeBITUSD,
    EOSFakeUSDT: require("./tokens/eos-fake-usdt").EOSFakeUSDT,
  }
};

// Categorize contracts
const evmTokens = [
  modules.tokens.TestnetUSDCred,
  modules.tokens.TestnetMBOTSPL,
  modules.tokens.SepoliaUSDT,
  modules.tokens.TestnetUSDT,
];

const eosTokens = [
  modules.tokens.EOSFakeBITUSD,
  modules.tokens.EOSFakeUSDT,
];

const auctions = [
  modules.auction.TestnetEasyAuction,
  modules.auction.TestnetDepositOrder,
];

export const devContracts = {
  tokens: {
    evm: evmTokens,
    eos: eosTokens,
  },
  auctions,
};

This approach reduces redundancy, makes the code easier to read, and simplifies the process of adding new contracts.

import { TestnetUSDCred } from "./tokens/testnet-usd-cred";
import { TestnetMBOTSPL } from "./tokens/testnet-mbots-prelaunch";
import { SepoliaUSDT } from "./tokens/sepolia-usdt";
import { TestnetUSDT } from "./tokens/testnet-usdt";
import { EOSFakeBITUSD } from "./tokens/eos-fake-bitusd";
import { EOSFakeUSDT } from "./tokens/eos-fake-usdt";
import {ContractData, EOSTokenContractData, EVMTokenContractData} from '../types';

const evmTokens: EVMTokenContractData[] = [
TestnetUSDCred,
TestnetMBOTSPL,
SepoliaUSDT,
TestnetUSDT,
]

const eosTokens: EOSTokenContractData[] = [
EOSFakeBITUSD,
EOSFakeUSDT,
]

const auctions: ContractData[] = [
TestnetEasyAuction,
TestnetDepositOrder,
]

export const devContracts = {
tokens: {
evm: evmTokens,
eos: eosTokens
},
auctions
}
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { TokenContractData } from "../types";
import { EOSTokenContractData} from '../../types';

export const EOSFakeBITUSD: TokenContractData = {
export const EOSFakeBITUSD: EOSTokenContractData = {
address: "bkbtokentest",
name: "BITUSD",
symbol: "BITUSD",
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { TokenContractData } from "../types";
import { EOSTokenContractData} from '../../types';

export const EOSFakeUSDT: TokenContractData = {
export const EOSFakeUSDT: EOSTokenContractData = {
address: "bkbmocktoken",
name: "Fake EOS USDT",
symbol: "USDT",
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { EVMTokenContractData } from "../types";
import { sepolia } from "viem/chains";
import { EVMTokenContractData } from "../../types";

export const SepoliaUSDT: EVMTokenContractData = {
address: "0x5b148580635e8b67184bcb496741e423f2c326bf",
Expand All @@ -9,6 +10,7 @@ export const SepoliaUSDT: EVMTokenContractData = {
chainId: 11155111, // sepolia
chainType: "evm",
chainName: "Sepolia",
chain: sepolia,
abi: [
{
inputs: [
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { EVMTokenContractData } from "../types";
import { EVMTokenContractData } from "../../types";
import {eosEvmTestnet} from '../../../../app-env/src/chains';

export const TestnetMBOTSPL: EVMTokenContractData = {
address: "0x357752b66961021524b44523cD90a8B3861803E5",
Expand All @@ -9,6 +10,7 @@ export const TestnetMBOTSPL: EVMTokenContractData = {
chainId: 15557,
chainType: "evm",
chainName: "EOS EVM Tesnet",
chain: eosEvmTestnet,
abi: [
{
inputs: [
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { EVMTokenContractData } from "../types";
import { EVMTokenContractData } from "../../types";
import {eosEvmTestnet} from '../../../../app-env/src/chains';

export const TestnetUSDCred: EVMTokenContractData = {
address: "0x1d5A4C37e60cAd0C72c057E3c191352429cDB38e",
Expand All @@ -9,6 +10,7 @@ export const TestnetUSDCred: EVMTokenContractData = {
chainId: 15557,
chainType: "evm",
chainName: "EOS EVM Tesnet",
chain: eosEvmTestnet,
abi: [
{
inputs: [
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { EVMTokenContractData } from "../types";
import { EVMTokenContractData } from "../../types";
import {eosEvmTestnet} from '../../../../app-env/src/chains';

export const TestnetUSDT: EVMTokenContractData = {
address: "0xE561021FCB5FFB86b439ae9e6AeCE0370e2394eC",
Expand All @@ -9,6 +10,7 @@ export const TestnetUSDT: EVMTokenContractData = {
chainId: 15557, // eos_evm
chainType: "evm",
chainName: "EOS EVM Tesnet",
chain: eosEvmTestnet,
abi: [
{
inputs: [
Expand Down
Loading
Loading