Skip to content

Latest commit

 

History

History
69 lines (47 loc) · 2.19 KB

README.md

File metadata and controls

69 lines (47 loc) · 2.19 KB

Futarchy TypeScript SDK for The MetaDAO

The Futarchy TypeScript SDK provides developers with a powerful, easy-to-use interface to interact with futarchy-based Solana programs deployed by The MetaDAO that enabled proposals powered by decision-markets. This SDK abstracts away ,any complexities, allowing developers to manage DAOs, proposals, and token balances with simple, asynchronous function calls.

Features

  • DAO Management: Fetch details of all DAOs or a specific DAO within The MetaDAO ecosystem.
  • Proposals: Retrieve proposals associated with a DAO, along with their respective vaults.
  • Token Balances: Query wallet balances of DAO tokens as well as conditional tokens of proposals for DAO members.

Installation

pnpm install -P @metadaoproject/futarchy-sdk

Usage

To start using the SDK, you need to import it into your project, along with necessary types from Solana's web3.js library. You can import the RPC client for example. Then you select the AUTOCRAT_VERSION you would like(0 is the latest). AUTOCRAT_VERSION refers to the version of the main Solana program that powers The MetaDAO.

import { PublicKey } from "@solana/web3.js";
import { FutarchyRPCClient, AUTOCRAT_VERSIONS } from "@metadaoproject/futarchy-sdk";

Initializing the Client

Now with the goodies imported, initialize the FutarchyRPCClient.

const provider = new AnchorProvider(connection, wallet, {});
const programVersion = AUTOCRAT_VERSIONS[0];
const client = FutarchyRPCClient.make(programVersion, provider);

Fetching DAOs

To fetch all DAOs:

const daos = await client.daos.fetchAllDaos();

To fetch a specific DAO by its address:

const daoAddress = "YourDaoAddressHere";
const dao = await client.daos.fetchDao(daoAddress);

Working with Proposals

To fetch proposals for a specific DAO:

const proposals = await client.proposals.fetchProposals(dao);

Managing Token Balances

To fetch main token wallet balances for a DAO member:

const ownerWallet = new PublicKey("YourWalletPublicKeyHere");
const balances = await client.balances.fetchMainTokenWalletBalances(
  dao,
  ownerWallet
);