This repository provides tools and scripts for fetching the Interface Definition Language (IDL) of deployed programs on the Solana blockchain using the @project-serum/anchor
library. This project is set up using TypeScript and includes essential modules to facilitate IDL fetching and management.
Services are for hire, contact me at https://t.me/@dwlee918
In this example you can see me run the script for the pump.fun program and the marinade finance program
example.mp4
- Fetch IDL of deployed programs on the Solana blockchain.
- Saves the IDL to a json file for further usage or storage
- Easy integration into existing projects.
Ensure you have the following installed:
- Node.js (version 14 or later)
- npm
- TypeScript
To install the package, clone the repository and install the dependencies:
git clone https://github.com/derricklee918/Sol-IDL-fetcher.git
cd Sol-IDL-fetcher
npm install
To compile and run the scripts:
- Configure your environment variables as instructed.
- Compile the TypeScript files:
npx tsc
- Run the compiled JavaScript file:
node example.js
In order to use the fetchIdl
method, an IDL must have been previously initialized via the Anchor CLI's anchor idl init
command. For example, the pump.fun
program with the ID 6EF8rrecthR5Dkzon8Nwu78hRvfCKubJ14M5uBEwF6P
will not work on mainnet-beta, but if you try it on devnet it will actually return the valid program IDL.
/**
* Fetches an idl from the blockchain.
*
* In order to use this method, an IDL must have been previously initialized
* via the anchor CLI's `anchor idl init` command.
*
* @param programId The on-chain address of the program.
* @param provider The network and wallet context.
*/
public static async fetchIdl<IDL extends Idl = Idl>(
address: Address,
provider?: Provider
): Promise<IDL | null> {
provider = provider ?? getProvider();
const programId = translateAddress(address);
const idlAddr = await idlAddress(programId);
const accountInfo = await provider.connection.getAccountInfo(idlAddr);
if (!accountInfo) {
return null;
}
// Chop off account discriminator.
let idlAccount = decodeIdlAccount(accountInfo.data.slice(8));
const inflatedIdl = inflate(idlAccount.data);
return JSON.parse(utf8.decode(inflatedIdl));
}
example.ts
: Main code filepackage.json
: Project metadata and dependencies.tsconfig.json
: TypeScript configuration file.
Contributions are welcome! Please fork the repository and submit a pull request with your improvements.
- Fork the repository
- Create your feature branch (
git checkout -b feature/YourFeature
) - Commit your changes (
git commit -m 'Add some feature'
) - Push to the branch (
git push origin feature/YourFeature
) - Open a pull request