Skip to main content
Glama

Alchemy MCP Server

Official
alchemyApi.ts6.4 kB
import dotenv from 'dotenv'; dotenv.config(); import { createPricesClient, createMultiChainTokenClient, createMultiChainTransactionHistoryClient, createAlchemyJsonRpcClient, createNftClient } from './alchemyClients.js'; import { TokenPriceBySymbol, TokenPriceByAddress, TokenPriceByAddressPair, TokenPriceHistoryBySymbol, MultiChainTokenByAddress, MultiChainTransactionHistoryByAddress, AssetTransfersParams, NftsByAddressParams, NftContractsByAddressParams, AddressPair, SendTransactionParams, SwapParams } from '../types/types.js'; import convertHexBalanceToDecimal from '../utils/convertHexBalanceToDecimal.js'; const AGENT_WALLET_SERVER = process.env.AGENT_WALLET_SERVER; export const alchemyApi = { async getTokenPriceBySymbol(params: TokenPriceBySymbol) { try { const client = createPricesClient(); const queryParams = new URLSearchParams(); params.symbols.forEach(symbol => { queryParams.append('symbols', symbol.toUpperCase()); }); const response = await client.get(`/by-symbol?${queryParams}`); return response.data; } catch (error) { console.error('Error fetching token prices:', error); throw error; } }, async getTokenPriceByAddress(params: TokenPriceByAddress) { try { const client = createPricesClient(); const response = await client.post('/by-address', { addresses: params.addresses.map((pair: TokenPriceByAddressPair) => ({ address: pair.address, network: pair.network })) }); console.log('Successfully fetched token price:', response.data); return response.data; } catch (error) { console.error('Error fetching token price:', error); throw error; } }, async getTokenPriceHistoryBySymbol(params: TokenPriceHistoryBySymbol) { console.log('Fetching token price history for symbol:', params.symbol); try { const client = createPricesClient(); const response = await client.post('/historical', { ...params }); console.log('Successfully fetched token price history:', response.data); return response.data; } catch (error) { console.error('Error fetching token price history:', error); throw error; } }, async getTokensByMultichainAddress(params: MultiChainTokenByAddress) { try { const client = createMultiChainTokenClient(); const response = await client.post('/by-address', { addresses: params.addresses.map((pair: AddressPair) => ({ address: pair.address, networks: pair.networks })) }); const responseData = convertHexBalanceToDecimal(response); return responseData; } catch (error) { console.error('Error fetching token data:', error); throw error; } }, async getTransactionHistoryByMultichainAddress(params: MultiChainTransactionHistoryByAddress) { try { const { addresses, ...otherParams } = params; const client = createMultiChainTransactionHistoryClient(); const response = await client.post('/by-address', { addresses: params.addresses.map((pair: AddressPair) => ({ address: pair.address, networks: pair.networks })), ...otherParams }); return response.data; } catch (error) { console.error('Error fetching transaction history:', error); throw error; } }, async getAssetTransfers(params: AssetTransfersParams) { const { network, ...otherParams } = params; try { const client = createAlchemyJsonRpcClient(network); const response = await client.post('', { method: "alchemy_getAssetTransfers", params: [{ ...otherParams }] }); return response.data; } catch (error) { console.error('Error fetching asset transfers:', error); throw error; } }, async getNftsForAddress(params: NftsByAddressParams) { try { const client = createNftClient(); const response = await client.post('/by-address', { ...params }); return response.data; } catch (error) { console.error('Error fetching NFTs for address:', error); throw error; } }, async getNftContractsByAddress(params: NftContractsByAddressParams) { try { const client = createNftClient(); const response = await client.post('/by-address', { ...params }); return response.data; } catch (error) { console.error('Error fetching NFT contracts by address:', error); throw error; } }, async sendTransaction(params: SendTransactionParams) { const { ownerScaAccountAddress, signerAddress, toAddress, value, callData } = params; try { const response = await fetch(`${AGENT_WALLET_SERVER}/transactions/send`, { method: 'POST', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify({ ownerScaAccountAddress, signerAddress, toAddress, value, callData }) }); if (!response.ok) { const errorData = await response.json(); throw new Error(errorData.error || `HTTP ${response.status}: ${response.statusText}`); } const result = await response.json(); return result.data; } catch (error) { console.error('Error sending transaction:', error); throw error; } }, async swap(params: SwapParams) { const { ownerScaAccountAddress, signerAddress } = params; console.error('SWAPPING TOKENS'); try { const response = await fetch(`${AGENT_WALLET_SERVER}/transactions/swap`, { method: 'POST', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify({ ownerScaAccountAddress, signerAddress }) }); console.error('SWAPPING TOKENS RESPONSE', response); if (!response.ok) { const errorData = await response.json(); throw new Error(errorData.error || `HTTP ${response.status}: ${response.statusText}`); } const result = await response.json(); return result.data; } catch (error) { console.error('Error in swap:', error); throw error; } } };

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/alchemyplatform/alchemy-mcp-server'

If you have feedback or need assistance with the MCP directory API, please join our Discord server